如何在Python中将字符串1和0保存为二进制文件

时间:2019-11-17 18:29:26

标签: python python-3.x bitstream

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

谢谢!

1 个答案:

答案 0 :(得分:1)

一旦有了二进制文件,就不必担心音频从哪里开始,等等,库应该为您完成。要使用bitstring保存字符串,可以一次完成所有操作,保存为字符串,然后像以下那样运行BitStream:

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

您的问题有几个可移动的部分,但是如果您的一个零的字符串正在与golomb一起使用,那么您从BitString读回的二进制文件应该可以正常工作。

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