使用 python 脚本,我想打印出以下十六进制输出:
hex_values = \
"\x31\xdb\xf7\xe3\x53\x43\x53\x6a\x02\x89\xe1\xb0\x66\xcd" + \
"\x80\x5b\x5e\x52\x68\x02\x00\x1a\x0a\x6a\x10\x51\x50\x89" + \
"\x80\x43\xb0\x66\xcd\x80\x93\x59\x6a\x3f\x58\xcd\x80\x49" + \
"\x50\x53\x89\xe1\xb0\x0b\xcd\x80"
使用 print hex_values
。
这最终输出:
./test
1���SCSj���f̀[^Rh
jQP��C�f̀�Yj?X̀IPS���
这是预期的。但是,当我将此输出输入编译后的 C 文件时,类似
./compiled_c_here $(test)
编译后的 C 文件会出错,提示实际上输入的参数太多。这是因为 python 脚本输出一个十六进制序列,该序列在 ASCII 字符之间有空格,这导致可执行文件认为这是 2 个输入一个长的十六进制字符串。
注意:如果十六进制输出没有空格,编译的 C 文件将正确运行(但是,我相信我不能忽略空格,因为它们代表一些 ASCII 序列)。
编译后的 C 文件对我来说基本上是一个黑盒子,我希望能够保留十六进制输出,这样它的行为就好像接收到的 ASCII 字符代表初始十六进制值一样。
从初始 python 脚本打印十六进制值的好方法是什么,这样它们就可以解释为单个十六进制字符串,而无需修改已编译的 C 文件。
最佳答案
用引号将数据括起来
./compiled_c_here "$(test)"
关于python - 将带空格的 Python 十六进制输出送入已编译的 C 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22366132/