下面的代码以二进制模式读取文件(此示例中为图像):
with open("img_80px.png", mode='rb') as file:
file_content = file.read()
binary_data = []
for i in file_content:
binary_data.append(i)
现在,打印出来file_content
将为我们提供二进制b' '
格式的十六进制值字符串:
b'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00P\x00\x00\x00<
\x08\x06\x00\x00\x00\xf1\'=\x8c\x00\x00\x00\tpHYs\x00\x00\x0fa
\x00\x00\x0fa\x01\xa8?\xa7i\x00\x009\xeeiTXtXML:com.adobe.xmp
\x00\\x00\x00\x00\x00<?xpacket begin="\xef\xbb\xbf" id="W5M0MpCehiHzreSzNTczkc9d"?>
\n<x:xmpmeta xmlns:x="adobe:ns:meta/"
x:xmptk="Adobe XMP Core 5.6-c138 79.159824, 2016/09/14-01:09:01
....'
因此,代码通过遍历file_content
并将每一位附加到binary_data
(不知道这是否是最好的方法,甚至不确定为什么会起作用)将该二进制字符串转换为数字列表,因此我们得到了:
[137, 80, 78, 71, 13, 10, 26, 10, 0, 0, 0, 13 ....]
问题是,如何将该列表转换回该b''
十六进制二进制字符串或其他内容?如您所见,它\x
在那里具有纯文本形式的值和元数据。不知道如何将其转换回去。
如果这种转换方式是强制性的,您是否可以建议另一种将二进制转换为整数字符串并返回的方法?
binary_data_string = "".join(map(str, binary_data))
with open("edited_img_80px.png", mode='wb') as edited_file:
binary_hex = bytes.fromhex(binary_data_string)
edited_file.write(binary_hex)
它抛出一个错误:
ValueError: non-hexadecimal number found in fromhex() arg at position 58313
而且我还尝试不将其转换为字符串,以保留列表中每个转换后的项目的信息,并能够将其转换回二进制,但是我得到了:
TypeError: fromhex() argument must be str, not list
由于您使用的是Python 3,因此可以执行以下操作:
>>>numbers = [222, 173, 190, 239]
>>>bytes(numbers)
b'\xde\xad\xbe\xef'
干杯!
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句