Python二进制通信:struct、array、ctypes模块比较

简介: Python是一种广泛应用于数据处理和网络编程的语言。在与C语言或其他设备进行二进制通信时,Python需要使用一些专门的模块来转换数据格式。本文将介绍三个常用的模块:struct、array、ctypes,并从结构说明和性能分析两方面进行比较。

{13F7CD3A-29A5-35E8-44C2-76C84C34FB55}.pngPython是一种广泛应用于数据处理和网络编程的语言。在与C语言或其他设备进行二进制通信时,Python需要使用一些专门的模块来转换数据格式。本文将介绍三个常用的模块:struct、array、ctypes,并从结构说明和性能分析两方面进行比较。

模块

结构说明

适用范围

struct

提供了pack和unpack函数,可以将Python数据转换为字节流,或者将字节流转换为Python数据。它适合处理简单的数据结构,如整数、浮点数、字符串等,但不支持复杂的数据结构,如指针、数组、结构体等。

适合处理简单且固定长度的数据

array

提供了一个类似于列表的对象,可以存储一组相同类型的值,并且占用更少的内存空间。它适合处理一维数组,但不支持多维数组或其他复杂类型。

适合处理大量相同类型且长度可变的数据

ctypes

提供了Structure类,可以直接定义与C语言中相同的结构体,并且支持指针、数组等复杂类型。它适合处理复杂的数据结构,并且可以方便地与动态链接库交互。

适合处理复杂且长度不定

从上图可以看出,在二进制通信中,

  • struct模块有最高的效率,因为它直接使用Python内置 的C函数进行数据转换, 而不需要额外 的对象或内存分配 。它也支持缓冲区协议, 可以避免 数据拷贝。
  • array模块有最低 的效率, 因为它需要创建一个数组对象, 并且每次转换 数据都需要调用方法或属性 。它也不支持缓冲区协议, 所以不能直接与动态链接库交互。
  • ctypes模块 的效率介于struct和array之间, 因为它可以直接定义与C语言兼容 的数据类型, 并且支持缓冲区协议。 但是它也需要创建一些对象, 并且有一些额外 的开销。

综上所述,如果需要处理简单的数据结构,struct模块在二进制通信中有最高的效率。但是,如果需要处理复杂的数据结构,ctypes模块可能是一个更好的选择,因为它支持指针、数组等复杂类型。array模块适合处理一维数组,但在性能方面较低,不支持缓冲区协议,所以不能直接与动态链接库交互。

下面使用ctypes模块进行通信:

# 导入ctypes模块importctypes# 定义一个C语言中的结构体classData(ctypes.Structure):
# 指定结构体的字段和类型_fields_= [
        ("id", ctypes.c_int),
        ("name", ctypes.c_char*20),
        ("value", ctypes.c_float)
    ]
# 创建一个Data数组,并赋值data_array= (Data*3)()
data_array[0].id=1data_array[0].name=b"jack"data_array[0].value=3.14data_array[1].id=2data_array[1].name=b"rose"data_array[1].value=4.56data_array[2].id=3data_array[2].name=b"jack"data_array[2].value=7.89# 导入httpx模块和threading模块importhttpximportthreading# 代理服务器(产品官网 www.16yun.cn)proxyHost="t.16yun.cn"proxyPort="31111"# 代理验证信息proxyUser="16yun"proxyPass="16ip"proxyMeta="http://%(user)s:%(pass)s@%(host)s:%(port)s"% {
"host": proxyHost,
"port": proxyPort,
"user": proxyUser,
"pass": proxyPass,
}
# 设置 http和https访问都是用HTTP代理proxies= {
"http://": proxyMeta,
"https://": proxyMeta,
}
# 定义一个函数,用于发送POST请求,并接收响应内容defsend_request(data):
# 将Data对象转换为字节流bytes_data=bytes(data)
# 创建一个httpx客户端,并设置爬虫加强版代理IPclient=httpx.Client(proxies)
# 发送POST请求,将字节流作为请求体,并设置超时时间为10秒钟response=client.post("http://www.16yun.cn/api", data=bytes_data, timeout=10)
# 打印响应状态码和内容print(response.status_code)
print(response.text)
# 遍历Data数组中的每个元素,判断其name是否等于jack,如果是,则创建一个线程并执行send_request函数,并将该元素作为参数传递给函数;如果不是,则跳过该元素。fordataindata_array:
ifdata.name==b"jack":
thread=threading.Thread(target=send_request, args=(data,))
thread.start()

上述代码通过ctypes.Structure实现指针、数组的复杂类型,然后使用代理IP进行post,实现快速的二进制通信。

相关文章
|
2月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
57 4
|
20天前
|
Python
Python Internet 模块
Python Internet 模块。
118 74
|
2月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
118 63
|
2月前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
2月前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
2月前
|
JSON Linux 数据格式
Python模块:从入门到精通,只需一篇文章!
Python中的模块是将相关代码组织在一起的单元,便于重用和维护。模块可以是Python文件或C/C++扩展,Python标准库中包含大量模块,如os、sys、time等,用于执行各种任务。定义模块只需创建.py文件并编写代码,导入模块使用import语句。此外,Python还支持自定义模块和包,以及虚拟环境来管理项目依赖。
Python模块:从入门到精通,只需一篇文章!
|
2月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
45 5
|
2月前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
2月前
|
JavaScript 前端开发 Python
python中的OS模块的基本使用
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。博客分享前端技术及全栈开发经验,持续更新中,期待您的关注和支持!🎉🎉🎉
40 0
|
2月前
|
JavaScript 前端开发 Python
python中的platform模块的基本使用
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。博客分享前端技术,助你成长。关注我,持续更新中!🎉🎉🎉
28 0