python 实现modBus协议的crc校验算法

循环冗余校验(CRC)是一种广泛用于数据传输错误检测的编码技术。本文介绍了CRC的基本原理,包括信息码与校验码的构成,以及模2除法的计算过程。并提供了使用Python的crcmod库计算16位CRC校验的示例代码,展示了如何将CRC校验添加到数据中,确保数据的完整性和准确性。
摘要由CSDN通过智能技术生成

CRC校验

循环冗余校验码(cyclic redundancy check)简称CRC(循环码),是一种能力相当强的检错、纠错码,并且实现编码和检码的电路比较简单,常用于串行传送(二进制位串沿一条信号线逐位传送)的辅助存储器与主机的数据通信和计算机网络中。

算法介绍

循环冗余校验码由信息码n位和校验码k位构成。k位校验位拼接在n位数据位后面,n+k为循环冗余校验码的字长,又称这个校验码(n+k,n)码。
n位信息位可以表示成为一个报文多项式M(x),最高幂次是xn-1。约定的生成多项式G(x)是一个k+1位的二进制数,最高幂次是xk。将M(x)乘以xk,即左移k位后,除以G(x),得到的k位余数就是校验位。这里的除法运算是模2除法,即当部分余数首位是1时商取1,反之商取0。然后每一位的减法运算是按位减,不产生借位。

代码实现

python有一个专门用于crc校验的库(crcmod),下面代码需要此库的支持。
安装:pip install crcmod
以下实例代码是计算16位的crc校验,如需其他crc校验可以查看库案例说明。

def crc16Add(read):
    crc16 = crcmod.mkCrcFun(0x18005, rev=True, initCrc=0xFFFF, xorOut=0x0000)
    data = read.replace(" ", "")
    readcrcout = hex(crc16(unhexlify(data))).upper()
    print(readcrcout)
    str_list = list(readcrcout)
    print(str_list)
    if len(str_list) == 5:
        str_list.insert(2, '0') 
    crc_data = "".join(str_list)
    print(crc_data)
    print('CRC16校验: %s' % (crc_data[4:] + ' ' + crc_data[2:4]))
    read = data + crc_data[4:] + crc_data[2:4]
    
    print('增加Modbus_CRC16校验:>>> %s' % read)
    return read


if __name__ == '__main__':
    crc16Add("0141FD0300")

运行结果

在这里插入图片描述

  • 4
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要在Python实现Modbus CRC校验,可以使用crcmod库。首先,确保已经安装了crcmod库(可以使用pip install crcmod进行安装)。然后,可以使用以下代码来计算CRC校验: ```python import crcmod def calculate_crc(data): crc16 = crcmod.mkCrcFun(0x18005, rev=True, initCrc=0xFFFF, xorOut=0x0000) crc_result = crc16(data) crc_hex = hex(crc_result)[2:].upper() crc_formatted = crc_hex.zfill(4) return crc_formatted data = "0141FD0300" crc = calculate_crc(bytes.fromhex(data)) print("CRC16校验: %s" % crc) ``` 这段代码使用crcmod.mkCrcFun函数创建了一个CRC校验函数,通过将数据转换为字节类型并传入该函数进行计算,得到了CRC校验值。最后,使用hex函数将校验值转换为十六进制字符串,并进行格式化输出。 希望以上信息对您有所帮助!123 #### 引用[.reference_title] - *1* [python 实现modBus协议crc校验算法](https://blog.csdn.net/youngdianfeng/article/details/113794945)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* *3* [用Python实现ModbusTcp协议](https://blog.csdn.net/silencestarsky/article/details/123678669)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值