gpt4 book ai didi

python - 如何在Python中将1's and 0'的字符串以二进制形式保存到二进制文件中

转载 作者:行者123 更新时间:2023-12-01 06:53:27 25 4
gpt4 key购买 nike

我目前正在尝试完成一个学校项目,其中涉及读取音频“wav”文件,使用golomb编码器对样本进行编码,将结果写入二进制文件,在另一个脚本上读取该二进制文件并对其进行解码使用哥伦布解码器。作业指南建议我开发一个 BitStream 类,它可以读写一位,也可以读写 n 位。我已经完成了哥伦布编码器和解码器,它似乎运行良好。但是,我在使用 BitStream 部分时遇到了问题。我尝试过在线搜索现有类(class),但由于我对编程相当陌生,因此它们看起来都非常复杂。我的 golomb 编码器返回一个由 1 和 0 组成的字符串,解码器使用类似的字符串作为输入。我的另一个问题是:当我编写完二进制文件后,我如何知道每个示例代码的开始和结束位置?如何将采样频率传递给解码器?我如何知道音频样本的左声道和右声道从哪里开始和结束?如何对每个单独样本的哥伦布编码器的 M 参数进行编码?顺便说一下,我应该用 Python 来做这件事。

提前致谢!

最佳答案

一旦你有了二进制文件,你就不必担心音频从哪里开始等,库应该为你做这些。要使用位字符串保存字符串,您可以一次性完成所有操作,保存到字符串,然后运行 ​​BitStream,如下所示:

BitStream(bin='101010101').tofile(filename)  

你的问题有一些移动部分,但是如果你的一串零可以与golomb一起使用,那么你从BitString读回的二进制文件应该按原样工作。

我有一个技巧,我也将其用于霍夫曼编码器。如果您使用编码生成的二进制字符串曾经以“0000”开头,则在写入之前始终在二进制字符串前面添加“1”,并在读取时删除前面添加的“1”。这使您不必存储有关二进制缓冲区保存的外部数据,因为二进制文件必须以前导 1 存储

关于python - 如何在Python中将1's and 0'的字符串以二进制形式保存到二进制文件中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58903779/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com