Python 使用print输出二进制文件时产生的错位

项目实践中,

python 复制代码
with open(fileName, 'rb') as f: 
	result = f.read()
	print(result)
	f.close()

打开二进制文件,打印出的结果会出现有些\x后面有好几个字符的情况

但实际这串数字是

这种情况是因为print函数将二进制数据解释为字符串并以其字节值的十六进制表示形式显示不可打印字符。

要避免这种情况,解决方法是:

  1. 使用hex()方法:将二进制数据转换为十六进制字符串,这样每个字节都会以两个字符表示。
python 复制代码
with open('fileName', 'rb') as f:
    result = f.read()
    print(result.hex())
  1. 使用binascii模块:该模块提供了将二进制数据转换为十六进制表示的便捷方法。
python 复制代码
import binascii

with open('fileName', 'rb') as f:
    result = f.read()
    print(binascii.hexlify(result).decode('ascii'))
  1. 使用repr()函数:虽然这不会完全避免\x的出现,但它会确保所有不可打印字符都被正确地转义并显示。(不推荐)
python 复制代码
with open('fileName', 'rb') as f:
    result = f.read()
    print(repr(result))

示例代码如下:

python 复制代码
with open(fileName, 'rb') as f: 
	result = f.read()
	print(result)
	f.close()
print(result.hex())
print(binascii.hexlify(result).decode('ascii'))
print(repr(result))

运行结果

这里不推荐第三种方式,他虽然能保留字节的形式,但不一定就能解析正确。

相关推荐
多恩Stone13 分钟前
【3DV 进阶-5】3D生成中 Inductive Bias (归纳偏置)的技术路线图
人工智能·python·算法·3d·aigc
恋恋西风15 分钟前
Qt 打开文件列表选择文件,实现拖拽方式打开文件,拖拽加载
开发语言·qt
闲人编程27 分钟前
使用Python进行量化交易入门
开发语言·python·统计分析·lambda·量化·codecapsule
移远通信1 小时前
常见问题解答
开发语言·php
初见无风1 小时前
3.1 Lua代码中的元表与元方法
开发语言·lua·lua5.4
逻极2 小时前
Rust流程控制(上):if_else与match模式匹配
开发语言·后端·rust
小雨下雨的雨2 小时前
Rust专项——其他集合类型详解:BTreeMap、VecDeque、BinaryHeap
开发语言·后端·rust
长颈鹿仙女2 小时前
发送 Prompt 指令:判断用户评价是好评还是差评
python·大模型
渡我白衣2 小时前
C++世界的混沌边界:undefined_behavior
java·开发语言·c++·人工智能·深度学习·语言模型
剑海风云2 小时前
JDK 26:HTTP/3 支持已可在 HTTP 客户端 API 中使用
java·开发语言·http