最近项目中要使用模拟数据源通过向外发送数据,以前都是用C#编写,最近在研究python,所以就用python写了一个串口助手,方便以后的测试。

在电脑上通过虚拟串口助手产生两个虚拟串口,运行编写的串口助手

另外,打开一个串口调试助手,辅助测试

  两者互发数据,可以看到编写的串口助手能够正常接收发送,并且在后台我们也把接收到的数据打印了出来

下面先讲解关于界面的代码,这里只是简单的使用tkinter做界面,如果想要更好的界面效果,可以尝试一下QT。

首先是界面中串口设置区域的代码,界面布局统一用grid来布局,当然也有其他的布局方法

 #-------------------------------------------------------------------------
#面板布局区
root = Tk()
root.title('xutopia 公众号:洛水梅家') #-------------------------------------------------------------------------
#串口设置区
label_com = Label(root, text="串口号", height=2).grid(row=0, column=0)
label_bps = Label(root, text="波特率", height=2).grid(column=0, row=1)
label_datBit = Label(root, text="数据位", height=2).grid(column=0, row=2)
label_parity = Label(root, text="校验位", height=2).grid(column=0, row=3)
label_stop_bit = Label(root, text="停止位", height=2).grid(column=0, row=4)

接下来是串口号的combobox的设置,其中serialPortFile.GetCom()是获取所有串口号的函数,接下来会讲解

#串口号
varPort = StringVar()
combo_com = ttk.Combobox(root, textvariable=varPort, width=8, height=2, justify=CENTER)
serial_com = serialPortFile.GetCom()
combo_com['values'] = serial_com
#combo_com.bind("<<ComboboxSelected>>", lambda event: combo1_handler(var=varPort.get()))
combo_com.current(0)
combo_com.grid(column=1, row=0)
 #波特率
varBitrate = StringVar()
combo_bps = ttk.Combobox(root, textvariable=varBitrate, width=8, height=2, justify=CENTER)
combo_bps['values'] = ("", "", "", "")
#combo_bps.bind("<<ComboboxSelected>>", lambda event: combo2_handler(var=varBitrate.get()))
combo_bps.current(0)
combo_bps.grid(column=1, row=1)
#数据位
combo_byteBit = ttk.Combobox(root, width=8, height=2, justify=CENTER)
combo_byteBit['values'] = ("", "", "", "")
combo_byteBit.current(3)
combo_byteBit.grid(column=1, row=2)
#奇偶校验
combo_parity = ttk.Combobox(root, width=8, height=2, justify=CENTER)
combo_parity['values'] = ("N", "O", "E")
combo_parity.current(0)
combo_parity.grid(column=1, row=3)
#停止位
combo_stopBit = ttk.Combobox(root, width=8, height=2, justify=CENTER)
combo_stopBit['values'] = ("", "1.5", "")
combo_stopBit.current(0)
combo_stopBit.grid(column=1, row=4)
serialPortFile.text_rx = Text(root,width=70,height=20)
serialPortFile.text_rx.grid(row=0,column=3,rowspan=5)
serialPortFile.text_rx.insert(END,'这是一个xutopia用python编写的串口助手,公众号:洛水梅家\n')
text_tx = Text(root,width=70,height=10)
text_tx.grid(row=5,column=3,rowspan=2)
text_tx.insert(END,'xutopia 公众号:洛水梅家,发送数据12345,上山打老虎')
button_send = Button(root, text='send', width=18, height=1)
button_send.bind("<Button-1>", lambda event: serialPortFile.usart_sent(var=text_tx.get("0.0", "end")))
button_send.grid(column=1, row=6)
#串口开关按钮
serialPortFile.button_var = StringVar()
serialPortFile.button_var.set("打开串口")
buttonOpenCom = Button(root, textvariable=serialPortFile.button_var, width=18, height=1)
buttonOpenCom.bind("<Button-1>", lambda event: serialPortFile.usart_ctrl(combo_com.get(), combo_bps.get(),combo_parity.get(),combo_stopBit.get(),combo_byteBit.get()))
buttonOpenCom.grid(column=1, row=5)

以上就是界面相关的代码,最终效果也就是上图显示的效果,很简单。接下来介绍python串口的逻辑代码部分。在另外一个模块中serialPortFile.py

获取电脑中所有的串口号的函数,注意这里通过serial.tools.list_ports.comports()获取所有的串口号之后进行了一步转换,存在一个数组中,这样,传入serial中才能被识别。

 # 获取并存储串口号到数组
def GetCom():
port_list = list(serial.tools.list_ports.comports())
print(len(port_list))
portcnt = len(port_list)
serial_com = []
for m in range(portcnt):
port_list_1 = list(port_list[m])
serial_com.append(port_list_1[0])
return serial_com

串口打开关闭函数,串口打开之后创建了一个线程threading,线程中一直监视串口的状态,一旦接受到数据,就把数据显示到接受数据显示框中。有关python线程threading的内容可以在我的公众号,洛水梅家中查看。

注意在代码中加了一个if ser.is_open:的条件判断,不加入这个条件的话,很有可能重复打开串口而报错误。

同时在按键Button的状态也随着串口的开关状态而变化。

def usart_ctrl(com, bps,parity_,stopbits_,bytesize_):
#print(__file__, sys._getframe().f_lineno, port_, bitrate_, var.get())
global ser, button_var
if button_var.get() == "打开串口":
button_var.set("关闭串口")
ser = serial.Serial(
port=com,
baudrate=int(bps),
parity=parity_,
timeout=0.2,
stopbits=float(stopbits_),
bytesize=int(bytesize_))
if ser.is_open:
pass
else:
ser.open()
recv_data = threading.Thread(target=thread_recv)
recv_data.start()
else:
button_var.set("打开串口")
if ser.is_open:
ser.close()
else:
pass
def usart_sent(var):
#print(__file__, sys._getframe().f_lineno, "-->", var)
print(var)
if ser.is_open:
ser.write(var.encode("gb2312"))
def thread_recv():
global text_rx
while True:
try:
read = ser.readall()
if len(read) > 0:
print(bytes(read).decode('gb2312'))
# print(__file__, sys._getframe().f_lineno, "<--", bytes(read).decode('ascii'))
text_rx.insert(END,bytes(read).decode('gb2312'))
except Exception as e:
print(e)
time.sleep(1)
pass

上面就是关于串口助手的所有代码介绍,更多详细内容,关注公众号 洛水梅家 免费获取源码

后台回复python_com,免费获取源码

python串口助手的更多相关文章

  1. Python串口编程

    python的串口网上有很多例子,这里了只是把认为好的整理到一起. 首先,应该安装serial模块,还能开始后续的操作.我用的python2.6,serial模块可以在这里下载安装serial模块下载 ...

  2. python3 Serial 串口助手的接收读取数据

    其实网上已经有许多python语言书写的串口,但大部分都是python2写的,没有找到一个合适的python编写的串口助手,只能自己来写一个串口助手,由于我只需要串口能够接收读取数据就可以了,故而这个 ...

  3. raspi串口、python串口模块pyserial

    一.安装 1.下载软件包pyserial-2.7.tar.gz   网址:https://pypi.python.org/pypi/pyserial 2.8uftp上传至/usr/local/src/ ...

  4. 谢欣伦 - OpenDev原创例程 - 串口助手Comm Assist

    前一段时间,一位博友发邮件给我.他跟我讲说没太看懂<化繁为简系列原创教程 - 通信专题 - 串口类CxComm的使用>,请我做一个DEMO工程给他.我抽了一天时间编写并上传了一个DEMO工 ...

  5. 34.QT-制作串口助手(并动态检测在线串口,附带源码)

    qextserialport-1.2rc库下载链接: http://www.pudn.com/Download/item/id/2298532.html 1.添加源码到工程 将qextserialpo ...

  6. Qt小项目之串口助手控制LED

    Qt小项目之串口助手控制LED 前言 最近刚学了一点Qt开发上位机,尝试着做个小软件练练手.查找了很多资料,做了一个简单的串口助手,可以实现串口基本发送和接收功能,支持中文显示,还可以控制STM32开 ...

  7. 用 PYQT5 和 QT Dseingner 写的串口助手

    最近公司做项目需要写串口助手,于是从网上找教程着手写了一下,基本的功能可以实现了,但是想要一个表盘的功能一直没有找到教程,有些遗憾.大神们会的话给指导指导  谢谢啦 ! 下边有源码的连接,欢迎大家下载 ...

  8. 通过编写串口助手工具学习MFC过程--(十一)弹出模态型对话框

    通过编写串口助手工具学习MFC过程 因为以前也做过几次MFC的编程,每次都是项目完成时,MFC基本操作清楚了,但是过好长时间不再接触MFC的项目,再次做MFC的项目时,又要从头开始熟悉.这次通过做一个 ...

  9. 通过编写串口助手工具学习MFC过程——(十)UpdateData()用法和编辑框的赋值、取值

    通过编写串口助手工具学习MFC过程 因为以前也做过几次MFC的编程,每次都是项目完成时,MFC基本操作清楚了,但是过好长时间不再接触MFC的项目,再次做MFC的项目时,又要从头开始熟悉.这次通过做一个 ...

随机推荐

  1. poj 3468 A Simple Problem with Integers(原来是一道简单的线段树区间修改用来练练splay)

    题目链接:http://poj.org/problem?id=3468 题解:splay功能比线段树强大当然代价就是有些操作比线段树慢,这题用splay实现的比线段树慢上一倍.线段树用lazy标记差不 ...

  2. hdu6376 度度熊剪纸条 思维

    度度熊剪纸条 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  3. hdu 6016 Count the Sheep(思维)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6016 题意:给定男羊和女羊的朋友关系,即给定一个图,问从任意一只羊开始连续数四只不相同的羊的方法数. ...

  4. codeforces 747D. Winter Is Coming(贪心)

    题目链接:http://codeforces.com/problemset/problem/747/D 题意:冬天有n天,冬天用的轮胎总共能用k天,一开始车子用的是夏天的轮胎. 给出n天的平均气温,温 ...

  5. 《即时消息技术剖析与实战》学习笔记4——IM系统如何保证消息的可靠性

    IM 系统中,保证消息的可靠投递主要体现在两方面,一是消息的不丢失,二是消息的不重复. 一.消息不丢失 消息丢失的原因 首先看一下发送消息的流程,如下图所示: 消息.可以采取"时间戳比对&q ...

  6. 从零开始开发IM(即时通讯)服务端(二)

    好消息:IM1.0.0版本已经上线啦,支持特性: 私聊发送文本/文件 已发送/已送达/已读回执 支持使用ldap登录 支持接入外部的登录认证系统 提供客户端jar包,方便客户端开发 github链接: ...

  7. SpringBoot 2.0 + 阿里巴巴 Sentinel 动态限流实战

    前言 在从0到1构建分布式秒杀系统和打造十万博文系统中,限流是不可缺少的一个环节,在系统能承受的范围内既能减少资源开销又能防御恶意攻击. 在前面的文章中,我们使用了开源工具包 Guava 提供的限流工 ...

  8. Appium+python自动化(三十七)- 士兵突击许三多 - 多个appium服务启动,多个设备启动,多进程并发启动设备-并发测试 - 下(超详解)

    简介 接着上一篇继续看一下如何并发测试以及并发测试的过程中,可能遇到的问题,在这里宏哥把宏哥遇到的和小伙伴或者童鞋们,一起分享一下. Appium端口检测 问题思考 经过前面学习,我们已经能够使用py ...

  9. .Net基础篇_学习笔记_第三天_运算符

    入门编程思想,由传统“算法”引申到“编程”思想 using System; using System.Collections.Generic; using System.Linq; using Sys ...

  10. STL中nth_element的用法

    nth_element函数原型有四个,详细我就不一一累赘了,我们就用最普通的用法寻找第k位置的元素. 函数用法为:nth_element(first,kth,end). first,last 第一个和 ...