| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | :mod:`aifc` --- Read and write AIFF and AIFC files
 | 
					
						
							|  |  |  | ==================================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. module:: aifc
 | 
					
						
							|  |  |  |    :synopsis: Read and write audio files in AIFF or AIFC format.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. index::
 | 
					
						
							|  |  |  |    single: Audio Interchange File Format
 | 
					
						
							|  |  |  |    single: AIFF
 | 
					
						
							|  |  |  |    single: AIFF-C
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-24 16:28:06 +00:00
										 |  |  | **Source code:** :source:`Lib/aifc.py`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | This module provides support for reading and writing AIFF and AIFF-C files.
 | 
					
						
							|  |  |  | AIFF is Audio Interchange File Format, a format for storing digital audio
 | 
					
						
							|  |  |  | samples in a file.  AIFF-C is a newer version of the format that includes the
 | 
					
						
							|  |  |  | ability to compress the audio data.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-27 16:20:50 +00:00
										 |  |  | .. note::
 | 
					
						
							| 
									
										
										
										
											2009-01-03 21:18:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-17 00:24:54 +00:00
										 |  |  |    Some operations may only work under IRIX; these will raise :exc:`ImportError`
 | 
					
						
							| 
									
										
										
										
											2009-04-27 16:20:50 +00:00
										 |  |  |    when attempting to import the :mod:`cl` module, which is only available on
 | 
					
						
							|  |  |  |    IRIX.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Audio files have a number of parameters that describe the audio data. The
 | 
					
						
							|  |  |  | sampling rate or frame rate is the number of times per second the sound is
 | 
					
						
							|  |  |  | sampled.  The number of channels indicate if the audio is mono, stereo, or
 | 
					
						
							|  |  |  | quadro.  Each frame consists of one sample per channel.  The sample size is the
 | 
					
						
							|  |  |  | size in bytes of each sample.  Thus a frame consists of
 | 
					
						
							|  |  |  | *nchannels*\**samplesize* bytes, and a second's worth of audio consists of
 | 
					
						
							|  |  |  | *nchannels*\**samplesize*\**framerate* bytes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For example, CD quality audio has a sample size of two bytes (16 bits), uses two
 | 
					
						
							|  |  |  | channels (stereo) and has a frame rate of 44,100 frames/second.  This gives a
 | 
					
						
							|  |  |  | frame size of 4 bytes (2\*2), and a second's worth occupies 2\*2\*44100 bytes
 | 
					
						
							|  |  |  | (176,400 bytes).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Module :mod:`aifc` defines the following function:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-02 02:56:10 +00:00
										 |  |  | .. function:: open(file, mode=None)
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Open an AIFF or AIFF-C file and return an object instance with methods that are
 | 
					
						
							| 
									
										
										
										
											2010-09-15 11:11:28 +00:00
										 |  |  |    described below.  The argument *file* is either a string naming a file or a
 | 
					
						
							|  |  |  |    :term:`file object`.  *mode* must be ``'r'`` or ``'rb'`` when the file must be
 | 
					
						
							|  |  |  |    opened for reading, or ``'w'``  or ``'wb'`` when the file must be opened for writing.
 | 
					
						
							|  |  |  |    If omitted, ``file.mode`` is used if it exists, otherwise ``'rb'`` is used.  When
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  |    used for writing, the file object should be seekable, unless you know ahead of
 | 
					
						
							|  |  |  |    time how many samples you are going to write in total and use
 | 
					
						
							|  |  |  |    :meth:`writeframesraw` and :meth:`setnframes`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-26 15:02:41 +00:00
										 |  |  | Objects returned by :func:`.open` when a file is opened for reading have the
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | following methods:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getnchannels()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the number of audio channels (1 for mono, 2 for stereo).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getsampwidth()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the size in bytes of individual samples.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getframerate()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the sampling rate (number of audio frames per second).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getnframes()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the number of audio frames in the file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getcomptype()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-29 21:50:39 +00:00
										 |  |  |    Return a bytes array of length 4 describing the type of compression
 | 
					
						
							|  |  |  |    used in the audio file.  For AIFF files, the returned value is
 | 
					
						
							|  |  |  |    ``b'NONE'``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getcompname()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-29 21:50:39 +00:00
										 |  |  |    Return a bytes array convertible to a human-readable description
 | 
					
						
							|  |  |  |    of the type of compression used in the audio file.  For AIFF files,
 | 
					
						
							|  |  |  |    the returned value is ``b'not compressed'``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getparams()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return a tuple consisting of all of the above values in the above order.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getmarkers()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return a list of markers in the audio file.  A marker consists of a tuple of
 | 
					
						
							|  |  |  |    three elements.  The first is the mark ID (an integer), the second is the mark
 | 
					
						
							|  |  |  |    position in frames from the beginning of the data (an integer), the third is the
 | 
					
						
							|  |  |  |    name of the mark (a string).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.getmark(id)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the tuple as described in :meth:`getmarkers` for the mark with the given
 | 
					
						
							|  |  |  |    *id*.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.readframes(nframes)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Read and return the next *nframes* frames from the audio file.  The returned
 | 
					
						
							|  |  |  |    data is a string containing for each frame the uncompressed samples of all
 | 
					
						
							|  |  |  |    channels.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.rewind()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Rewind the read pointer.  The next :meth:`readframes` will start from the
 | 
					
						
							|  |  |  |    beginning.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setpos(pos)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Seek to the specified frame number.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.tell()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the current frame number.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.close()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Close the AIFF file.  After calling this method, the object can no longer be
 | 
					
						
							|  |  |  |    used.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-26 15:02:41 +00:00
										 |  |  | Objects returned by :func:`.open` when a file is opened for writing have all the
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | above methods, except for :meth:`readframes` and :meth:`setpos`.  In addition
 | 
					
						
							|  |  |  | the following methods exist.  The :meth:`get\*` methods can only be called after
 | 
					
						
							|  |  |  | the corresponding :meth:`set\*` methods have been called.  Before the first
 | 
					
						
							|  |  |  | :meth:`writeframes` or :meth:`writeframesraw`, all parameters except for the
 | 
					
						
							|  |  |  | number of frames must be filled in.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.aiff()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Create an AIFF file.  The default is that an AIFF-C file is created, unless the
 | 
					
						
							|  |  |  |    name of the file ends in ``'.aiff'`` in which case the default is an AIFF file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.aifc()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Create an AIFF-C file.  The default is that an AIFF-C file is created, unless
 | 
					
						
							|  |  |  |    the name of the file ends in ``'.aiff'`` in which case the default is an AIFF
 | 
					
						
							|  |  |  |    file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setnchannels(nchannels)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Specify the number of channels in the audio file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setsampwidth(width)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Specify the size in bytes of audio samples.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setframerate(rate)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Specify the sampling frequency in frames per second.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setnframes(nframes)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Specify the number of frames that are to be written to the audio file. If this
 | 
					
						
							|  |  |  |    parameter is not set, or not set correctly, the file needs to support seeking.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setcomptype(type, name)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. index::
 | 
					
						
							|  |  |  |       single: u-LAW
 | 
					
						
							|  |  |  |       single: A-LAW
 | 
					
						
							|  |  |  |       single: G.722
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-29 21:50:39 +00:00
										 |  |  |    Specify the compression type.  If not specified, the audio data will
 | 
					
						
							|  |  |  |    not be compressed.  In AIFF files, compression is not possible.
 | 
					
						
							|  |  |  |    The name parameter should be a human-readable description of the
 | 
					
						
							|  |  |  |    compression type as a bytes array, the type parameter should be a
 | 
					
						
							|  |  |  |    bytes array of length 4.  Currently the following compression types
 | 
					
						
							|  |  |  |    are supported: ``b'NONE'``, ``b'ULAW'``, ``b'ALAW'``, ``b'G722'``.
 | 
					
						
							| 
									
										
										
										
											2007-08-15 14:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setparams(nchannels, sampwidth, framerate, comptype, compname)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Set all the above parameters at once.  The argument is a tuple consisting of the
 | 
					
						
							|  |  |  |    various parameters.  This means that it is possible to use the result of a
 | 
					
						
							|  |  |  |    :meth:`getparams` call as argument to :meth:`setparams`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.setmark(id, pos, name)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Add a mark with the given id (larger than 0), and the given name at the given
 | 
					
						
							|  |  |  |    position.  This method can be called at any time before :meth:`close`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.tell()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return the current write position in the output file.  Useful in combination
 | 
					
						
							|  |  |  |    with :meth:`setmark`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.writeframes(data)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Write data to the output file.  This method can only be called after the audio
 | 
					
						
							|  |  |  |    file parameters have been set.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.writeframesraw(data)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Like :meth:`writeframes`, except that the header of the audio file is not
 | 
					
						
							|  |  |  |    updated.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. method:: aifc.close()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Close the AIFF file.  The header of the file is updated to reflect the actual
 | 
					
						
							|  |  |  |    size of the audio data. After calling this method, the object can no longer be
 | 
					
						
							|  |  |  |    used.
 | 
					
						
							|  |  |  | 
 |