我正试图以字符串转义的方式将python中的二进制文件( gzipped协议缓冲区对象)转换为十六进制字符串(例如。\xFA\x1C .)
我都试过了
repr(<mygzipfileobj>.getvalue())以及
<mygzipfileobj>.getvalue().encode('string-escape')在这两种情况下,我结束了一个字符串,它不是由HEX字符组成的。
\x86\xe3$T]\x0fPE\x1c\xaa\x1c8d\xb7\x9e\x127\xcd\x1a.\x88v ...如何实现一致的十六进制转换,其中每个字节实际上被转换为\xHH格式?(其中H代表有效的十六进制字符0-9A-F)
发布于 2016-05-19 07:39:37
您经常看到的\xhh格式是调试辅助工具,repr()的输出应用于具有非ASCII码点的字符串。任何ASCII码点都保留在原地,以便留下可读的信息.
如果必须使用all字符替换为\xhh转义符的字符串,则需要手动这样做:
''.join(r'\x{0:02x}'.format(ord(c)) for c in value)如果需要引号,也需要手动添加这些引号:
"'{0}'".format(''.join(r'\x{:02x}'.format(ord(c)) for c in value))https://stackoverflow.com/questions/37316698
复制相似问题