2007-08-15 11:28:22 -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.
|
|
|
|
|
2009-04-27 13:20:50 -03:00
|
|
|
.. note::
|
2009-01-03 17:18:54 -04:00
|
|
|
|
2007-08-16 21:24:54 -03:00
|
|
|
Some operations may only work under IRIX; these will raise :exc:`ImportError`
|
2009-04-27 13:20:50 -03:00
|
|
|
when attempting to import the :mod:`cl` module, which is only available on
|
|
|
|
IRIX.
|
2007-08-15 11:28:22 -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:
|
|
|
|
|
|
|
|
|
2009-04-01 23:56:10 -03:00
|
|
|
.. function:: open(file, mode=None)
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
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`.
|
|
|
|
|
Merged revisions 73941-73943,74076,74094,74186,74211-74214,74247,74254,74262,74311,74334,74368 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
r73941 | georg.brandl | 2009-07-11 12:39:00 +0200 (Sa, 11 Jul 2009) | 9 lines
Merged revisions 73940 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r73940 | georg.brandl | 2009-07-11 12:37:38 +0200 (Sa, 11 Jul 2009) | 1 line
#6430: add note about size of "u" type.
........
................
r73942 | georg.brandl | 2009-07-11 12:39:23 +0200 (Sa, 11 Jul 2009) | 1 line
#6430: remove mention of "w" array typecode.
................
r73943 | georg.brandl | 2009-07-11 12:43:08 +0200 (Sa, 11 Jul 2009) | 1 line
#6421: The self argument of module-level PyCFunctions is now a reference to the module object.
................
r74076 | georg.brandl | 2009-07-18 11:07:48 +0200 (Sa, 18 Jul 2009) | 1 line
#6502: add missing comma in docstring.
................
r74094 | georg.brandl | 2009-07-19 09:25:56 +0200 (So, 19 Jul 2009) | 10 lines
Recorded merge of revisions 74089 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74089 | senthil.kumaran | 2009-07-19 04:43:43 +0200 (So, 19 Jul 2009) | 3 lines
Fix for issue5102, timeout value propages between redirects, proxy, digest and
auth handlers. Fixed tests to reflect the same.
........
................
r74186 | georg.brandl | 2009-07-23 11:19:09 +0200 (Do, 23 Jul 2009) | 9 lines
Recorded merge of revisions 74185 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74185 | georg.brandl | 2009-07-23 11:17:09 +0200 (Do, 23 Jul 2009) | 1 line
Fix the "pylocals" gdb command.
........
................
r74211 | georg.brandl | 2009-07-26 16:48:09 +0200 (So, 26 Jul 2009) | 9 lines
Recorded merge of revisions 74210 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74210 | georg.brandl | 2009-07-26 16:44:23 +0200 (So, 26 Jul 2009) | 1 line
Move member descriptions inside the classes.
........
................
r74212 | georg.brandl | 2009-07-26 16:54:51 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74209 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74209 | georg.brandl | 2009-07-26 16:37:28 +0200 (So, 26 Jul 2009) | 1 line
builtin -> built-in.
........
................
r74213 | georg.brandl | 2009-07-26 17:02:41 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74207 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74207 | georg.brandl | 2009-07-26 16:19:57 +0200 (So, 26 Jul 2009) | 1 line
#6577: fix (hopefully) all links to builtin instead of module/class-specific objects.
........
................
r74214 | georg.brandl | 2009-07-26 17:03:49 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74205 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74205 | georg.brandl | 2009-07-26 15:36:39 +0200 (So, 26 Jul 2009) | 1 line
#6576: fix cross-refs in re docs.
........
................
r74247 | georg.brandl | 2009-07-29 09:27:08 +0200 (Mi, 29 Jul 2009) | 9 lines
Merged revisions 74239 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74239 | georg.brandl | 2009-07-28 18:55:32 +0000 (Di, 28 Jul 2009) | 1 line
Clarify quote_plus() usage.
........
................
r74254 | georg.brandl | 2009-07-29 18:14:16 +0200 (Mi, 29 Jul 2009) | 1 line
#6586: fix return/argument type doc for os.read() and os.write().
................
r74262 | alexandre.vassalotti | 2009-07-29 21:54:39 +0200 (Mi, 29 Jul 2009) | 57 lines
Merged revisions 74074,74077,74111,74188,74192-74193,74200,74252-74253,74258-74261 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74074 | georg.brandl | 2009-07-18 05:03:10 -0400 (Sat, 18 Jul 2009) | 1 line
#6513: fix example code: warning categories are classes, not instances.
........
r74077 | georg.brandl | 2009-07-18 05:43:40 -0400 (Sat, 18 Jul 2009) | 1 line
#6489: fix an ambiguity in getiterator() documentation.
........
r74111 | benjamin.peterson | 2009-07-20 09:30:10 -0400 (Mon, 20 Jul 2009) | 1 line
remove docs for deprecated -p option
........
r74188 | benjamin.peterson | 2009-07-23 10:25:31 -0400 (Thu, 23 Jul 2009) | 1 line
use bools
........
r74192 | georg.brandl | 2009-07-24 12:28:38 -0400 (Fri, 24 Jul 2009) | 1 line
Fix arg types of et#.
........
r74193 | georg.brandl | 2009-07-24 12:46:38 -0400 (Fri, 24 Jul 2009) | 1 line
Dont put "void" in signature for nullary functions.
........
r74200 | georg.brandl | 2009-07-25 09:02:15 -0400 (Sat, 25 Jul 2009) | 1 line
#6571: add index entries for more operators.
........
r74252 | georg.brandl | 2009-07-29 12:06:31 -0400 (Wed, 29 Jul 2009) | 1 line
#6593: fix link targets.
........
r74253 | georg.brandl | 2009-07-29 12:09:17 -0400 (Wed, 29 Jul 2009) | 1 line
#6591: add reference to ioctl in fcntl module for platforms other than Windows.
........
r74258 | georg.brandl | 2009-07-29 12:57:05 -0400 (Wed, 29 Jul 2009) | 1 line
Add a link to readline, and mention IPython and bpython.
........
r74259 | georg.brandl | 2009-07-29 13:07:21 -0400 (Wed, 29 Jul 2009) | 1 line
Fix some markup and small factual glitches found by M. Markert.
........
r74260 | georg.brandl | 2009-07-29 13:15:20 -0400 (Wed, 29 Jul 2009) | 1 line
Fix a few markup glitches.
........
r74261 | georg.brandl | 2009-07-29 13:50:25 -0400 (Wed, 29 Jul 2009) | 1 line
Rewrite the section about classes a bit; mostly tidbits, and a larger update to the section about "private" variables to reflect the Pythonic consensus better.
........
................
r74311 | georg.brandl | 2009-08-04 22:29:27 +0200 (Di, 04 Aug 2009) | 1 line
Slightly improve buffer-related error message.
................
r74334 | georg.brandl | 2009-08-06 19:51:03 +0200 (Do, 06 Aug 2009) | 1 line
#6648: mention surrogateescape handler where all standard handlers are listed.
................
r74368 | georg.brandl | 2009-08-13 09:56:35 +0200 (Do, 13 Aug 2009) | 21 lines
Merged revisions 74328,74332-74333,74365 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74328 | georg.brandl | 2009-08-06 17:06:25 +0200 (Do, 06 Aug 2009) | 1 line
Fix base keyword arg name for int() and long().
........
r74332 | georg.brandl | 2009-08-06 19:23:21 +0200 (Do, 06 Aug 2009) | 1 line
Fix punctuation and one copy-paste error.
........
r74333 | georg.brandl | 2009-08-06 19:43:55 +0200 (Do, 06 Aug 2009) | 1 line
#6658: fix two typos.
........
r74365 | georg.brandl | 2009-08-13 09:48:05 +0200 (Do, 13 Aug 2009) | 1 line
#6679: Remove mention that sub supports no flags.
........
................
2009-08-13 05:26:44 -03:00
|
|
|
Objects returned by :func:`.open` when a file is opened for reading have the
|
2007-08-15 11:28:22 -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()
|
|
|
|
|
2009-04-29 18:50:39 -03: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 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. method:: aifc.getcompname()
|
|
|
|
|
2009-04-29 18:50:39 -03: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 11:28:22 -03: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.
|
|
|
|
|
Merged revisions 73941-73943,74076,74094,74186,74211-74214,74247,74254,74262,74311,74334,74368 via svnmerge from
svn+ssh://svn.python.org/python/branches/py3k
................
r73941 | georg.brandl | 2009-07-11 12:39:00 +0200 (Sa, 11 Jul 2009) | 9 lines
Merged revisions 73940 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r73940 | georg.brandl | 2009-07-11 12:37:38 +0200 (Sa, 11 Jul 2009) | 1 line
#6430: add note about size of "u" type.
........
................
r73942 | georg.brandl | 2009-07-11 12:39:23 +0200 (Sa, 11 Jul 2009) | 1 line
#6430: remove mention of "w" array typecode.
................
r73943 | georg.brandl | 2009-07-11 12:43:08 +0200 (Sa, 11 Jul 2009) | 1 line
#6421: The self argument of module-level PyCFunctions is now a reference to the module object.
................
r74076 | georg.brandl | 2009-07-18 11:07:48 +0200 (Sa, 18 Jul 2009) | 1 line
#6502: add missing comma in docstring.
................
r74094 | georg.brandl | 2009-07-19 09:25:56 +0200 (So, 19 Jul 2009) | 10 lines
Recorded merge of revisions 74089 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74089 | senthil.kumaran | 2009-07-19 04:43:43 +0200 (So, 19 Jul 2009) | 3 lines
Fix for issue5102, timeout value propages between redirects, proxy, digest and
auth handlers. Fixed tests to reflect the same.
........
................
r74186 | georg.brandl | 2009-07-23 11:19:09 +0200 (Do, 23 Jul 2009) | 9 lines
Recorded merge of revisions 74185 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74185 | georg.brandl | 2009-07-23 11:17:09 +0200 (Do, 23 Jul 2009) | 1 line
Fix the "pylocals" gdb command.
........
................
r74211 | georg.brandl | 2009-07-26 16:48:09 +0200 (So, 26 Jul 2009) | 9 lines
Recorded merge of revisions 74210 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74210 | georg.brandl | 2009-07-26 16:44:23 +0200 (So, 26 Jul 2009) | 1 line
Move member descriptions inside the classes.
........
................
r74212 | georg.brandl | 2009-07-26 16:54:51 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74209 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74209 | georg.brandl | 2009-07-26 16:37:28 +0200 (So, 26 Jul 2009) | 1 line
builtin -> built-in.
........
................
r74213 | georg.brandl | 2009-07-26 17:02:41 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74207 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74207 | georg.brandl | 2009-07-26 16:19:57 +0200 (So, 26 Jul 2009) | 1 line
#6577: fix (hopefully) all links to builtin instead of module/class-specific objects.
........
................
r74214 | georg.brandl | 2009-07-26 17:03:49 +0200 (So, 26 Jul 2009) | 9 lines
Merged revisions 74205 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74205 | georg.brandl | 2009-07-26 15:36:39 +0200 (So, 26 Jul 2009) | 1 line
#6576: fix cross-refs in re docs.
........
................
r74247 | georg.brandl | 2009-07-29 09:27:08 +0200 (Mi, 29 Jul 2009) | 9 lines
Merged revisions 74239 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74239 | georg.brandl | 2009-07-28 18:55:32 +0000 (Di, 28 Jul 2009) | 1 line
Clarify quote_plus() usage.
........
................
r74254 | georg.brandl | 2009-07-29 18:14:16 +0200 (Mi, 29 Jul 2009) | 1 line
#6586: fix return/argument type doc for os.read() and os.write().
................
r74262 | alexandre.vassalotti | 2009-07-29 21:54:39 +0200 (Mi, 29 Jul 2009) | 57 lines
Merged revisions 74074,74077,74111,74188,74192-74193,74200,74252-74253,74258-74261 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74074 | georg.brandl | 2009-07-18 05:03:10 -0400 (Sat, 18 Jul 2009) | 1 line
#6513: fix example code: warning categories are classes, not instances.
........
r74077 | georg.brandl | 2009-07-18 05:43:40 -0400 (Sat, 18 Jul 2009) | 1 line
#6489: fix an ambiguity in getiterator() documentation.
........
r74111 | benjamin.peterson | 2009-07-20 09:30:10 -0400 (Mon, 20 Jul 2009) | 1 line
remove docs for deprecated -p option
........
r74188 | benjamin.peterson | 2009-07-23 10:25:31 -0400 (Thu, 23 Jul 2009) | 1 line
use bools
........
r74192 | georg.brandl | 2009-07-24 12:28:38 -0400 (Fri, 24 Jul 2009) | 1 line
Fix arg types of et#.
........
r74193 | georg.brandl | 2009-07-24 12:46:38 -0400 (Fri, 24 Jul 2009) | 1 line
Dont put "void" in signature for nullary functions.
........
r74200 | georg.brandl | 2009-07-25 09:02:15 -0400 (Sat, 25 Jul 2009) | 1 line
#6571: add index entries for more operators.
........
r74252 | georg.brandl | 2009-07-29 12:06:31 -0400 (Wed, 29 Jul 2009) | 1 line
#6593: fix link targets.
........
r74253 | georg.brandl | 2009-07-29 12:09:17 -0400 (Wed, 29 Jul 2009) | 1 line
#6591: add reference to ioctl in fcntl module for platforms other than Windows.
........
r74258 | georg.brandl | 2009-07-29 12:57:05 -0400 (Wed, 29 Jul 2009) | 1 line
Add a link to readline, and mention IPython and bpython.
........
r74259 | georg.brandl | 2009-07-29 13:07:21 -0400 (Wed, 29 Jul 2009) | 1 line
Fix some markup and small factual glitches found by M. Markert.
........
r74260 | georg.brandl | 2009-07-29 13:15:20 -0400 (Wed, 29 Jul 2009) | 1 line
Fix a few markup glitches.
........
r74261 | georg.brandl | 2009-07-29 13:50:25 -0400 (Wed, 29 Jul 2009) | 1 line
Rewrite the section about classes a bit; mostly tidbits, and a larger update to the section about "private" variables to reflect the Pythonic consensus better.
........
................
r74311 | georg.brandl | 2009-08-04 22:29:27 +0200 (Di, 04 Aug 2009) | 1 line
Slightly improve buffer-related error message.
................
r74334 | georg.brandl | 2009-08-06 19:51:03 +0200 (Do, 06 Aug 2009) | 1 line
#6648: mention surrogateescape handler where all standard handlers are listed.
................
r74368 | georg.brandl | 2009-08-13 09:56:35 +0200 (Do, 13 Aug 2009) | 21 lines
Merged revisions 74328,74332-74333,74365 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r74328 | georg.brandl | 2009-08-06 17:06:25 +0200 (Do, 06 Aug 2009) | 1 line
Fix base keyword arg name for int() and long().
........
r74332 | georg.brandl | 2009-08-06 19:23:21 +0200 (Do, 06 Aug 2009) | 1 line
Fix punctuation and one copy-paste error.
........
r74333 | georg.brandl | 2009-08-06 19:43:55 +0200 (Do, 06 Aug 2009) | 1 line
#6658: fix two typos.
........
r74365 | georg.brandl | 2009-08-13 09:48:05 +0200 (Do, 13 Aug 2009) | 1 line
#6679: Remove mention that sub supports no flags.
........
................
2009-08-13 05:26:44 -03:00
|
|
|
Objects returned by :func:`.open` when a file is opened for writing have all the
|
2007-08-15 11:28:22 -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
|
|
|
|
|
2009-04-29 18:50:39 -03: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 11:28:22 -03: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.
|
|
|
|
|