Python中的反向无符号字符

Inverse unsigned char in Python

本文关键字:无符号 字符 Python      更新时间:2023-10-16

我有C++的代码:

unsigned char LRC_form(char* cadr)
{
unsigned char LRC=0;
unsigned int t=0;
LRC=0;
for (t=1;t<0x0D;t=t+2)
{
LRC=LRC+ASCII2hex(cadr[t])*16+ASCII2hex(cadr[t+1]);
}
return ((~(LRC))+1);
}
int main(int argc, char *argv[])
{
char *p={":010600000045"};
cout<<LRC_form(p);
}

其中 ASCII2Hex 是一个将字符的 ASCII 代码转换为十六进制的函数。 我必须用 Python 编写相同的内容,所以我这样做:

def LRC_FORM():
LRC=0
string_to_send = "010600000045"
Arr = list(string_to_send)
#LRC = int(Arr[1])+2
#print(LRC)
counter=0
for i in string_to_send:
numb = int(i, 16)
if counter%2 == 0:
LRC = LRC + numb * 16
else:
LRC = LRC + numb
counter = counter + 1

但是我应该如何实现 (~LRC( + 1,因为 LRC 是一个无符号字符,在我的情况下它是 int,我可以使用一些模块,如 ctypes 或结构体,但是当我这样做时:

import ctypes
import struct
cchar1=(struct.pack('1B',LRC)) 
cchar2= ctypes.c_char(LRC) 

它没有给我我期待的结果。LRC = 77,我虽然我应该得到LRC = '77',但我得到b'L'所以它不会给出与C++中的代码相同的结果。 如何以正确的方式转换它?

提前谢谢你!

附言 C++程序输出

char *p={":010600000045"};
cout<<LRC_form(p);

正在给予76我正在尝试与Python 3相同

编辑 1

return LRC; 

在C程序中给出76. 这与我可以在我的 Python 代码中获得的相同。 但

return ((~(LRC))+1);

给了180,我不知道我应该怎么做才能在 Python 中获得相同的内容。

编辑 2

ASCII2十六进制函数:

unsigned char ASCII2hex (char ASCII)
{
if (ASCII<0x40)
return (ASCII-0x30);
else
return (ASCII-0x37);
}
enter code here

最简单的方法是让binascii.unhexlify完成大部分工作。我们只需要向它发送一个bytes字符串,而不是文本字符串。

import binascii
def lrc(s):
# Convert string s to bytes
b = s.encode('ascii')
# Interpret hex data in b
h = binascii.unhexlify(b)
# Add the byte values
return sum(h)
# test
s = "010600000045"
print(lrc(s))

输出

76

我们可以使该函数更加紧凑,尽管结果的可读性较差:

def lrc(s):
return sum(binascii.unhexlify(s.encode('ascii')))

我们可以轻松地在 Python 中((~(LRC))+1),但我们必须小心,原因有两个。首先,Python没有无符号整数,其次,Python的整数具有无限的精度。但我们可以通过提供合适的口罩来处理这两件事。如果我们想将结果限制为 8 位,我们可以使用0xff == 255掩码:

l = 76
print(l, (0xff & ~l) + 1)

输出

76 180

或者我们可以在反转位之后但在进行掩码之前进行加法:

0xff & (~l + 1)

您可以简单地使用 AND 0xff将结果强制回无符号字符范围:

return ((~LRC)+1) & 0xff