2007-08-15 11:28:01 -03: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
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
Merged revisions 72007-72010,72036-72037 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r72007 | georg.brandl | 2009-04-27 17:09:25 +0200 (Mo, 27 Apr 2009) | 1 line
#5856: fix typo s in traceback example.
........
r72008 | georg.brandl | 2009-04-27 17:10:44 +0200 (Mo, 27 Apr 2009) | 1 line
Remove ".. warning::" markup that doesnt contain warnings for users, rather todo items.
........
r72009 | georg.brandl | 2009-04-27 17:29:09 +0200 (Mo, 27 Apr 2009) | 3 lines
Demote warnings to notices where appropriate, following the goal that as few "red box" warnings
should clutter the docs as possible. Part 1: stuff that gets merged to Py3k.
........
r72010 | georg.brandl | 2009-04-27 17:29:26 +0200 (Mo, 27 Apr 2009) | 2 lines
Demote warnings to notices, part 2: stuff that is 2.x-only.
........
r72036 | georg.brandl | 2009-04-27 19:04:23 +0200 (Mo, 27 Apr 2009) | 1 line
#5848: small unittest doc patch.
........
r72037 | georg.brandl | 2009-04-27 19:09:53 +0200 (Mo, 27 Apr 2009) | 1 line
#5840: dont claim we dont support TLS.
........
2009-04-28 15:23:28 -03:00
|
|
|
.. note::
|
Merged revisions 68133-68134,68141-68142,68145-68146,68148-68149,68159-68162,68166,68171-68174,68179,68195-68196,68210,68214-68215,68217-68222 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68133 | antoine.pitrou | 2009-01-01 16:38:03 +0100 (Thu, 01 Jan 2009) | 1 line
fill in actual issue number in tests
........
r68134 | hirokazu.yamamoto | 2009-01-01 16:45:39 +0100 (Thu, 01 Jan 2009) | 2 lines
Issue #4797: IOError.filename was not set when _fileio.FileIO failed to open
file with `str' filename on Windows.
........
r68141 | benjamin.peterson | 2009-01-01 17:43:12 +0100 (Thu, 01 Jan 2009) | 1 line
fix highlighting
........
r68142 | benjamin.peterson | 2009-01-01 18:29:49 +0100 (Thu, 01 Jan 2009) | 2 lines
welcome to 2009, Python!
........
r68145 | amaury.forgeotdarc | 2009-01-02 01:03:54 +0100 (Fri, 02 Jan 2009) | 5 lines
#4801 _collections module fails to build on cygwin.
_PyObject_GC_TRACK is the macro version of PyObject_GC_Track,
and according to documentation it should not be used for extension modules.
........
r68146 | ronald.oussoren | 2009-01-02 11:44:46 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4472: "configure --enable-shared doesn't work on OSX"
........
r68148 | ronald.oussoren | 2009-01-02 11:48:31 +0100 (Fri, 02 Jan 2009) | 2 lines
Forgot to add a NEWS item in my previous checkin
........
r68149 | ronald.oussoren | 2009-01-02 11:50:48 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4780
........
r68159 | ronald.oussoren | 2009-01-02 15:48:17 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue 1627952
........
r68160 | ronald.oussoren | 2009-01-02 15:52:09 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue r1737832
........
r68161 | ronald.oussoren | 2009-01-02 16:00:05 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 1149804
........
r68162 | ronald.oussoren | 2009-01-02 16:06:00 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 4472 is incompatible with Cygwin, this patch
should fix that.
........
r68166 | benjamin.peterson | 2009-01-02 19:26:23 +0100 (Fri, 02 Jan 2009) | 1 line
document PyMemberDef
........
r68171 | georg.brandl | 2009-01-02 21:25:14 +0100 (Fri, 02 Jan 2009) | 3 lines
#4811: fix markup glitches (mostly remains of the conversion),
found by Gabriel Genellina.
........
r68172 | martin.v.loewis | 2009-01-02 21:32:55 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4075: Use OutputDebugStringW in Py_FatalError.
........
r68173 | martin.v.loewis | 2009-01-02 21:40:14 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4051: Prevent conflict of UNICODE macros in cPickle.
........
r68174 | benjamin.peterson | 2009-01-02 21:47:27 +0100 (Fri, 02 Jan 2009) | 1 line
fix compilation on non-Windows platforms
........
r68179 | raymond.hettinger | 2009-01-02 22:26:45 +0100 (Fri, 02 Jan 2009) | 1 line
Issue #4615. Document how to use itertools for de-duping.
........
r68195 | georg.brandl | 2009-01-03 14:45:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove useless string literal.
........
r68196 | georg.brandl | 2009-01-03 15:29:53 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix indentation.
........
r68210 | georg.brandl | 2009-01-03 20:10:12 +0100 (Sat, 03 Jan 2009) | 2 lines
Set eol-style correctly for mp_distributing.py.
........
r68214 | georg.brandl | 2009-01-03 20:44:48 +0100 (Sat, 03 Jan 2009) | 2 lines
Make indentation consistent.
........
r68215 | georg.brandl | 2009-01-03 21:15:14 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix role name.
........
r68217 | georg.brandl | 2009-01-03 21:30:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Add rstlint, a little tool to find subtle markup problems and inconsistencies in the Doc sources.
........
r68218 | georg.brandl | 2009-01-03 21:38:59 +0100 (Sat, 03 Jan 2009) | 2 lines
Recognize usage of the default role.
........
r68219 | georg.brandl | 2009-01-03 21:47:01 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix uses of the default role.
........
r68220 | georg.brandl | 2009-01-03 21:55:06 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove trailing whitespace.
........
r68221 | georg.brandl | 2009-01-03 22:04:55 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove tabs from the documentation.
........
r68222 | georg.brandl | 2009-01-03 22:11:58 +0100 (Sat, 03 Jan 2009) | 2 lines
Disable the line length checker by default.
........
2009-01-03 17:55:17 -04:00
|
|
|
|
2007-08-15 16:06:04 -03:00
|
|
|
Some operations may only work under IRIX; these will raise :exc:`ImportError`
|
Merged revisions 72007-72010,72036-72037 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r72007 | georg.brandl | 2009-04-27 17:09:25 +0200 (Mo, 27 Apr 2009) | 1 line
#5856: fix typo s in traceback example.
........
r72008 | georg.brandl | 2009-04-27 17:10:44 +0200 (Mo, 27 Apr 2009) | 1 line
Remove ".. warning::" markup that doesnt contain warnings for users, rather todo items.
........
r72009 | georg.brandl | 2009-04-27 17:29:09 +0200 (Mo, 27 Apr 2009) | 3 lines
Demote warnings to notices where appropriate, following the goal that as few "red box" warnings
should clutter the docs as possible. Part 1: stuff that gets merged to Py3k.
........
r72010 | georg.brandl | 2009-04-27 17:29:26 +0200 (Mo, 27 Apr 2009) | 2 lines
Demote warnings to notices, part 2: stuff that is 2.x-only.
........
r72036 | georg.brandl | 2009-04-27 19:04:23 +0200 (Mo, 27 Apr 2009) | 1 line
#5848: small unittest doc patch.
........
r72037 | georg.brandl | 2009-04-27 19:09:53 +0200 (Mo, 27 Apr 2009) | 1 line
#5840: dont claim we dont support TLS.
........
2009-04-28 15:23:28 -03:00
|
|
|
when attempting to import the :mod:`cl` module, which is only available on
|
|
|
|
IRIX.
|
2007-08-15 11:28:01 -03: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:
|
|
|
|
|
|
|
|
|
|
|
|
.. function:: open(file[, mode])
|
|
|
|
|
|
|
|
Open an AIFF or AIFF-C file and return an object instance with methods that are
|
|
|
|
described below. The argument *file* is either a string naming a file or a 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
|
|
|
|
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-10-27 11:36:50 -03:00
|
|
|
Objects returned by :func:`.open` when a file is opened for reading have the
|
2007-08-15 11:28:01 -03: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()
|
|
|
|
|
|
|
|
Return a four-character string describing the type of compression used in the
|
|
|
|
audio file. For AIFF files, the returned value is ``'NONE'``.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: aifc.getcompname()
|
|
|
|
|
|
|
|
Return a human-readable description of the type of compression used in the audio
|
|
|
|
file. For AIFF files, the returned value is ``'not compressed'``.
|
|
|
|
|
|
|
|
|
|
|
|
.. 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-10-27 11:36:50 -03:00
|
|
|
Objects returned by :func:`.open` when a file is opened for writing have all the
|
2007-08-15 11:28:01 -03: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
|
|
|
|
|
|
|
|
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, the type
|
|
|
|
parameter should be a four-character string. Currently the following
|
|
|
|
compression types are supported: NONE, ULAW, ALAW, G722.
|
|
|
|
|
|
|
|
|
|
|
|
.. 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.
|
|
|
|
|