这个出crc16 的程序是根据c语言上的crc16算法改过来的,网上几乎找不到Python的crc16直接计算例程
亲测可用:已经使用在项目上。因为在crc16校验中,计算出来的crc16数值是16位(uint_16)的,因为Python的整数是没有最大值的,所以计算出的16位的数值是跟c语言的不一样。但是传输数据使用8位的数据,所以需要分为两个8位的数据才可用,分出来的计算结果跟c语言计算的结果是一样的,所以可以使用:
def crc16(self, strbuf, lenth):
result = 0
tempcrc16 = 0
tempdata = 0
m = 0
n = 0
result = result
for m in range(lenth):
result = (result & 0xFFFF) # 因为Python的int整形数没有最大值,所以需要&上0xffff
tempcrc16 = (tempcrc16 & 0xFFFF) # 因为Python的int整形数没有最大值,所以需要&上0xffff
tempdata = (tempdata & 0xFFFF) # 因为Python的int整形数没有最大值,所以需要&上0xffff
tempcrc16 = (((result >> 8) ^ strbuf[m]) & 0xffff)
tempdata = (tempcrc16 << 8)
tempcrc16 = 0
for n in range(8):
if ((tempdata ^ tempcrc16) & 0x8000):
tempcrc16 = (((tempcrc16 << 1)) ^ 0x1021)
else:
tempcrc16 = (tempcrc16 << 1)
tempdata = (tempdata << 1)
# print(tempcrc16)
result = ((result << 8) ^ tempcrc16)
return result
#使用方式:例子如下:
buf = [0x06,0xaa,0x02,0x01]
print(crc16(buf ,len(buf))) #6695815
print((crc16(buf ,len(buf))&0xff)) #135
print(((crc16(buf ,len(buf))>>8)&0xff)) #43