52 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| :mod:`sndhdr` --- Determine type of sound file
 | |
| ==============================================
 | |
| 
 | |
| .. module:: sndhdr
 | |
|    :synopsis: Determine type of a sound file.
 | |
| 
 | |
| .. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
 | |
| .. Based on comments in the module source file.
 | |
| 
 | |
| **Source code:** :source:`Lib/sndhdr.py`
 | |
| 
 | |
| .. index::
 | |
|    single: A-LAW
 | |
|    single: u-LAW
 | |
| 
 | |
| --------------
 | |
| 
 | |
| The :mod:`sndhdr` provides utility functions which attempt to determine the type
 | |
| of sound data which is in a file.  When these functions are able to determine
 | |
| what type of sound data is stored in a file, they return a
 | |
| :func:`~collections.namedtuple`, containing five attributes: (``filetype``,
 | |
| ``framerate``, ``nchannels``, ``nframes``, ``sampwidth``). The value for *type*
 | |
| indicates the data type and will be one of the strings ``'aifc'``, ``'aiff'``,
 | |
| ``'au'``, ``'hcom'``, ``'sndr'``, ``'sndt'``, ``'voc'``, ``'wav'``, ``'8svx'``,
 | |
| ``'sb'``, ``'ub'``, or ``'ul'``.  The *sampling_rate* will be either the actual
 | |
| value or ``0`` if unknown or difficult to decode.  Similarly, *channels* will be
 | |
| either the number of channels or ``0`` if it cannot be determined or if the
 | |
| value is difficult to decode.  The value for *frames* will be either the number
 | |
| of frames or ``-1``.  The last item in the tuple, *bits_per_sample*, will either
 | |
| be the sample size in bits or ``'A'`` for A-LAW or ``'U'`` for u-LAW.
 | |
| 
 | |
| 
 | |
| .. function:: what(filename)
 | |
| 
 | |
|    Determines the type of sound data stored in the file *filename* using
 | |
|    :func:`whathdr`.  If it succeeds, returns a namedtuple as described above, otherwise
 | |
|    ``None`` is returned.
 | |
| 
 | |
|    .. versionchanged:: 3.5
 | |
|       Result changed from a tuple to a namedtuple.
 | |
| 
 | |
| 
 | |
| .. function:: whathdr(filename)
 | |
| 
 | |
|    Determines the type of sound data stored in a file based on the file  header.
 | |
|    The name of the file is given by *filename*.  This function returns a namedtuple as
 | |
|    described above on success, or ``None``.
 | |
| 
 | |
|    .. versionchanged:: 3.5
 | |
|       Result changed from a tuple to a namedtuple.
 | |
| 
 |