http://www.douban.com/group/topic/7400483/
如何用python写个串口通信的程序?
2009-07-26 16:08:18 来自: 如影随形(但行好事,莫问前程)
用tKinter做界面
-
-
-
2009-07-26 17:18:53 如影随形 (但行好事,莫问前程)
搜狐博客 > 一二三事 > 日志 2007-07-05 | python 串口通信 标签: python 串口 Jeffu:
我用的是“线程轮寻”方式。
就是打开串口后,启动一个线程来监听串口数据的进入,有数据时,就做数据的处理(也可以发送一个事件,并携带接收到的数据)。
我没有用到串口处理太深的东西。
客户的原程序不能给你,不过我给你改一下吧。
里面的一些东西,已经经过了处理,要运行,可能你要自己改一下,把没有用的东西去掉。
我这里已经没有串口设备了,不能调了,你自己处理一下吧,不过基本的东西已经有了。
=================================================================
#coding=gb18030
import sys,threading,time;
import serial;
import binascii,encodings;
import re;
import socket;
class ReadThread:
def __init__(self, Output=None, Port=0, Log=None, i_FirstMethod=True):
self.l_serial = None;
self.alive = False;
self.waitEnd = None;
self.bFirstMethod = i_FirstMethod;
self.sendport = '';
self.log = Log;
self.output = Output;
self.port = Port;
self.re_num = None;
def waiting(self):
if not self.waitEnd is None:
self.waitEnd.wait();
def SetStopEvent(self):
if not self.waitEnd is None:
self.waitEnd.set();
self.alive = False;
self.stop();
def start(self):
self.l_serial = serial.Serial();
self.l_serial.port = self.port;
self.l_serial.baudrate = 9600;
self.l_serial.timeout = 2;
self.re_num = re.compile('\d');
try:
if not self.output is None:
self.output.WriteText(u'打开通讯端口\r\n');
if not self.log is None:
self.log.info(u'打开通讯端口');
self.l_serial.open();
except Exception, ex:
if self.l_serial.isOpen():
self.l_serial.close();
self.l_serial = None;
if not self.output is None:
self.output.WriteText(u'出错:\r\n %s\r\n' % ex);
if not self.log is None:
self.log.error(u'%s' % ex);
return False;
if self.l_serial.isOpen():
if not self.output is None:
self.output.WriteText(u'创建接收任务\r\n');
if not self.log is None:
self.log.info(u'创建接收任务');
self.waitEnd = threading.Event();
self.alive = True;
self.thread_read = None;
self.thread_read = threading.Thread(target=self.FirstReader);
self.thread_read.setDaemon(1);
self.thread_read.start();
return True;
else:
if not self.output is None:
self.output.WriteText(u'通讯端口未打开\r\n');
if not self.log is None:
self.log.info(u'通讯端口未打开');
return False;
def InitHead(self):
#串口的其它的一些处理
try:
time.sleep(3);
if not self.output is None:
self.output.WriteText(u'数据接收任务开始连接网络\r\n');
if not self.log is None:
self.log.info(u'数据接收任务开始连接网络');
self.l_serial.flushInput();
self.l_serial.write('\x11');
data1 = self.l_serial.read(1024);
except ValueError,ex:
if not self.output is None:
self.output.WriteText(u'出错:\r\n %s\r\n' % ex);
if not self.log is None:
self.log.error(u'%s' % ex);
self.SetStopEvent();
return;
if not self.output is None:
self.output.WriteText(u'开始接收数据\r\n');
if not self.log is None:
self.log.info(u'开始接收数据');
self.output.WriteText(u'===================================\r\n');
def SendData(self, i_msg):
lmsg = '';
isOK = False;
if isinstance(i_msg, unicode):
lmsg = i_msg.encode('gb18030');
else:
lmsg = i_msg;
try:
#发送数据到相应的处理组件
pass
except Exception, ex:
pass;
return isOK;
def FirstReader(self):
data1 = '';
isQuanJiao = True;
isFirstMethod = True;
isEnd = True;
readCount = 0;
saveCount = 0;
RepPos = 0;
#read Head Infor content
self.InitHead();
while self.alive:
try:
data = '';
n = self.l_serial.inWaiting();
if n:
data = data + self.l_serial.read(n);
#print binascii.b2a_hex(data),
for l in xrange(len(data)):
if ord(data[l])==0x8E:
isQuanJiao = True;
continue;
if ord(data[l])==0x8F:
isQuanJiao = False;
continue;
if ord(data[l]) == 0x80 or ord(data[l]) == 0x00:
if len(data1)>10:
if not self.re_num.search(data1,1) is None:
saveCount = saveCount + 1;
if RepPos==0:
RepPos = self.output.GetInsertionPoint();
self.output.Remove(RepPos,self.output.GetLastPosition());
self.SendData(data1);
data1 = '';
continue;
except Exception, ex:
if not self.log is None:
self.log.error(u'%s' % ex);
self.waitEnd.set();
self.alive = False;
def stop(self):
self.alive = False;
self.thread_read.join();
if self.l_serial.isOpen():
self.l_serial.close();
if not self.output is None:
self.output.WriteText(u'关闭通迅端口:[%d] \r\n' % self.port);
if not self.log is None:
self.log.info(u'关闭通迅端口:[%d]' % self.port);
def printHex(self, s):
s1 = binascii.b2a_hex(s);
print s1;
#测试用部分
if __name__ == '__main__':
rt = ReadThread();
f = open("sendport.cfg", "r")
rt.sendport = f.read()
f.close()
try:
if rt.start():
rt.waiting();
rt.stop();
else:
pass;
except Exception,se:
print str(se);
if rt.alive:
rt.stop();
print 'End OK .';
del rt;
-
2009-07-26 17:20:45 如影随形 (但行好事,莫问前程)
这是个Tkinter界面,能不能把他们两个做个拼盘,
# -*- coding: utf-8 -*-
from Tkinter import *
import Tkinter
from tkMessageBox import *
class EntryDemo(Frame):
def __init__(self,parent):
Frame.__init__(self)
self.pack(expand=YES,fill=BOTH)
self.master.title("串口通信")
self.frame1=Frame(self)
self.frame1.pack(pady=5)
self.text1=Entry(self.frame1,name="显示")
self.text1.bind("<Return>",self.showContents)
self.text1.pack(side=LEFT,padx=5)
self.frame2=Frame(self)
self.frame2.pack(pady=5)
self.text2=Entry(self.frame2,name="显示")
self.text2.bind("<Return>",self.showContents)
self.text2.pack(side=LEFT,padx=5)
self.sendButton = Button(self.frame1, text="发送", command = self.pressedPlain)
self.sendButton.pack(side=LEFT, padx =5)
def showContents(self, event):
theName=event.widget.winfo_name()
theContents=event.widget.get()
showinfo("Message", theName +":"+ theContents)
def pressedPlain(self):
showinfo("Message","数据")
def main():
root = Tkinter.Tk()
widget = EntryDemo(root)
root.mainloop()
if __name__=="__main__":
main()
-
2009-07-26 19:40:14 如影随形 (但行好事,莫问前程)
我下载了pyserial,解压开有example, serials,把serial文件夹里的.py文件拷贝到python安装目录下的lib文件家里面吗?
分享到:
相关推荐
这是基于串口通信的python源程序,亲自调试没有问题。将自己PC通过串口连接其他PC或者兼容串口通信的设备或者传感器,可以读取到对方发送的数据。注意第一次发送的cmd地址指令集中的数据要符合自己的报文通信格式。
python串口通信,读取文件内容并通过串口传输至接收程序。
python 实现RFID串口数据读取(csdn)————程序
三菱FX3U PLC与串口助手进行串口通信收发数据测试,含串口助手详细配置步骤,PLC在串口收发数据过程中使用的特殊寄存器的使用说明以及其配置方法,含有串口通信的指令说明以及示例程序,包含单字节收发以及多字节...
串口通信其实没什么变化,唯一变化的就是协议。在vb.net中通过IronPython执行Python脚本进行串口通信,就可以让程序使用各种不同的协议。希望对大家有帮助。
使用python开发的一个串口上位机应用,主要使用的工具包有pyside2、PyQtgraphy、pyserial。程序入口文件为data_app.py
python使用serial模块,通过串口控制云台(基于PELCO-D协议)(csdn)————程序
ESP32的UART串口通信(基于micropython)中所展示的所有代码
使用Python编写的“串口与网口互通”程序。内含tkinter、serial、socket相关的详细注释,更有相关讲解,所谓可用可学。
采用Python编程语言实现modbusTCP 通信,资料包含有对寄存器操作例子
codesys实现的串口通讯,软件版本为V3.5,含说明文档。
pyqt5实现下位机串口通信程序,自定义波特率,校验码
三菱PLC与PC串口通信实现源代码;包含PLC程序和PC的vc++工程文件
使用wxpython 画UI写的一个串口小程序; 基于Mac系统的 简单的串口通信工具,附带源码。 有需要的可以参考一下
引言Python 是一种面向对象、解释型计算机程序设计语言,它的设计哲学是优雅、明确、简单。因为其开源免费的精神与简单易学的特点,自 1989 年问世以来, P
提取去其中的串口通信部分。代码更易读,VirtualComTest.py这个文件用于虚拟串口,需 在终端下执行 python VirtualComTest.py即可得到两个虚拟链接的串口端口,方便软件代 码的调试。程序中应用了modbus的...
串口通信是指外设和计算机间,通过数据信号线 、地线、控制线等,按位进行传输数据的一种通讯方式。这种通信方式使用的数据线少,在远距离通信中可以节约通信成本,但其传输速度比并行传输低。串口是计算机上一种...
下载/克隆后,为 Python 应用程序创建一个虚拟环境来运行 virtualenv venv 激活虚拟环境 . venv/bin/activate 使用 PIP 安装依赖项 pip install -r requirements.txt 跑步 目前没有太多可展示的,一堆 Tkinter ...
上位机的python加载软件通过该软件更新DSP的底层程序通过串口与下位机通信