繁体   English   中英

Python 3波模块字节序..?

[英]Python 3 wave module byteorder..?

[编辑:总之,这个问题是我对字节序的含义做出(显然不正确)假设的结果(我假设它是 00000001 与 10000000,即反转位,而不是字节)。 非常感谢@tripleee 解决了我的困惑。]

据我所知,Python 3 wave 模块 [1](我现在将其称为 pywave)返回的帧的字节顺序没有记录。 我已经查看了源代码 [2] [3],但还没有完全弄清楚。

首先,看起来 pywave 只支持“RIFF”波形文件 [2]。 'RIFF' 文件使用小端; 8 位或更低比特率的无符号,否则有符号(二进制补码)。

但是,看起来 pywave 将从文件中读取的字节转换为 sys.byteorder [2]:

data = self._data_chunk.read(nframes * self._framesize)
if self._sampwidth != 1 and sys.byteorder == 'big':
    data = audioop.byteswap(data, self._sampwidth)

除了sampwidth==1的情况,它对应于一个 8 位文件。 所以 8 位文件不会转换为 sys.byteorder? 为什么会这样? (也许是因为他们没有签名?)

目前我的逻辑如下:

if sampwidth == 1:
    signed = False
    byteorder = 'little'
else:
    signed = True
    byteorder = sys.byteorder

这个对吗?

8 位 wav 文件现在非常罕见,所以这不是一个真正的问题。 但我还是想找到答案...

[1] https://docs.python.org/3/library/wave.html

[2] https://github.com/python/cpython/blob/3.9/Lib/wave.py

[3] https://github.com/python/cpython/blob/3.9/Lib/chunk.py

一个字节就是一个字节,小端或大端只对超过一个字节的数据有意义。

  • 0xf0是单个 8 位字节。 在任何现代架构上,这些位都是0x11110000 如果没有符号位,范围是 0 到 255(8 位存储得到 2 8个可能的值)。

  • 0xf0eb是一个 16 位数字,用两个 8 位字节来表示。 这可以表示为

    • 0xf0 0xeb大端( 0x11110000 0x11101011 ),或
    • 0xeb 0xf0小端( 0x11101011 0x11110000

    没有符号位的可能值的范围是 0 到 65,535(2 16 个值)。

对于 32 位数字等,您还可以有不同的字节顺序,但我将按照Wikipedia等进行完整说明。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM