写入文件字节和字符串

Bor*_*rgo 2 python file-io byte python-3.x

我必须创建在 little-endian 编码中具有一些字符和十六进制值的文件。要进行编码,我使用:

pack("I", 0x01ddf23a)
Run Code Online (Sandbox Code Playgroud)

这给了我:

b':\xf2\xdd\x01'
Run Code Online (Sandbox Code Playgroud)

第一个问题是,这给了我无法写入文件的字节字符串。第二个是 \x3a 变成了 ':'。我期望的是写入文件 \x3a\xf2\xdd\x01 作为字节而不是字符。

我试过的:

>>> a=0x01ddf23a

>>> str(pack("I", a))
"b':\\xf2\\xdd\\x01'" <= wrong

>>> pack("I", a).hex()
'3af2dd01             <= I need '\x' before each byte

>>> pack("I", a).decode()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xf2 in position 1: invalid continuation byte
Run Code Online (Sandbox Code Playgroud)

将 open() 从“w”更改为“wb”迫使我只写字节,但我想写很多字符串和很少的字节,例如:

Hello world
^I^M^T^B
End file
Run Code Online (Sandbox Code Playgroud)

我知道我可以简单地做到这一点:

fs.open("file" "w")
fs.write("Hello world")
fs.write("\x3a\xf2\xdd\x01")
fs.write("End file")
fs.close()
Run Code Online (Sandbox Code Playgroud)

但这使我的字节值 0x01ddf23a 难以阅读,并且在以该形式更改此值时很容易犯一些错误。

Mar*_*ers 5

您正在生成字节,可以毫无问题地将其写入以二进制模式打开的文件b打开时添加到文件模式,bytes如果您还需要写入其他数据,请使用字符串文字或将字符串编码为字节:

with open("file", "wb") as fs:
    fs.write(b"Hello world")  # note, a byte literal!
    fs.write(pack("I", 0x01ddf23a))
    fs.write("End file".encode('ASCII'))  # encoded string to bytes
Run Code Online (Sandbox Code Playgroud)

另一种方法是首先将二进制打包数据解码为文本字符串,但由于打包数据实际上不包含可解码的文本,因此该方法需要扭曲 强制二进制数据再次可解码和编码,这仅适用如果您的文件编码设置为 Latin-1 并严重限制了您可以添加的实际文本。

一个bytes表示将始终尝试显示可打印字符在可能的情况。字节\x3a也是字符的正确 ASCII 值':',因此在bytes表示中,后者优于使用\x3a转义序列。的正确值出现在bytes值,并会完全正确写入文件:

>>> b'\x3a'
b':'
>>> b'\x3a' == b':'
True
>>> b':'[0]
58
>>> b'\x3a'[0]
58
>>> hex(58)
'0x3a'
Run Code Online (Sandbox Code Playgroud)