对Python 简单串口收发GUI界面的实例详解
作者:freedom098 发布时间:2023-03-29 05:50:18
标签:Python,串口,GUI
忙活了三个多小时,连学带做,总算是搞出来了一个具有基本功能的串口通信PC机的GUI界面,Tkinter在python中确实很好用,而且代码量确实也很少,不足的是Tkinter不自带combox,但是幸运的是我下载的2.7版本自带了包含有combox的ttk模块,于是乎问题就顺利解决了。
下面是源代码,一些错误提示功能还没有做,目前只是简单地实现了下位机与PC的通信界面,下位机还是用的STM32F103
#encoding=utf-8
__author__ = 'freedom'
from Tkinter import *
from serial import *
import ttk
class GUI(Frame):
def __init__(self,master):
frame = Frame(master)
frame.pack()
#串口设置相关变量
self.port = 0
self.baudrate = 9600
#串口号提示
self.lab1 = Label(frame,text = 'Serial Number')
self.lab1.grid(row = 0,column = 0,sticky = W)
#串口号选择下拉菜单
self.boxValue = StringVar()
self.boxChoice = ttk.Combobox(frame,textvariable = self.boxValue,state = 'readonly')
self.boxChoice['value'] = ('COM1','COM2','COM3','COM4')
self.boxChoice.current(0)
self.boxChoice.bind('<<ComboboxSelected>>',self.Choice)
self.boxChoice.grid(row = 1,column = 0,sticky = W)
#波特率选择提示
self.lab2 = Label(frame,text = 'Baudrate Set')
self.lab2.grid(row = 2,column = 0,sticky = W)
#波特率选择下拉菜单
self.boxValueBaudrate = IntVar()
self.BaudrateChoice = ttk.Combobox(frame,textvariable = self.boxValueBaudrate,state = 'readonly')
self.BaudrateChoice['value'] = (9600,115200)
self.BaudrateChoice.current(0)
self.BaudrateChoice.bind('<<ComboboxSelected>>',self.ChoiceBaudrate)
self.BaudrateChoice.grid(row = 3,column = 0,sticky = W)
#输出框提示
self.lab3 = Label(frame,text = 'Message Show')
self.lab3.grid(row = 0,column = 1,sticky = W)
#输出框
self.show = Text(frame,width = 40,height = 5,wrap = WORD)
self.show.grid(row = 1,column = 1,rowspan = 4,sticky = W)
#输入框提示
self.lab4 = Label(frame,text = 'Input here,please!')
self.lab4.grid(row = 5,column = 1,sticky = W)
#输入框
self.input = Entry(frame,width = 40)
self.input.grid(row = 6,column = 1,rowspan = 4,sticky = W)
#输入按钮
self.button1 = Button(frame,text = "Input",command = self.Submit)
self.button1.grid(row = 11,column = 1,sticky = E)
#串口开启按钮
self.button2 = Button(frame,text = 'Open Serial',command = self.open)
self.button2.grid(row = 7,column = 0,sticky = W)
#串口关闭按钮
self.button3 = Button(frame,text = 'Close Serial',command = self.close)
self.button3.grid(row = 10,column = 0,sticky = W)
#串口信息提示框
self.showSerial = Text(frame,width = 20,height = 2,wrap = WORD)
self.showSerial.grid(row = 12,column = 0,sticky = W)
#串口初始化配置
self.ser = Serial()
self.ser.setPort(self.port)
#self.ser.setBaudrate(self.baudrate)
#self.ser.open()
#print self.ser.isOpen()
#print self.ser
def Choice(self,event):
context = self.boxValue.get()
list = ["COM1",'COM2','COM3','COM4']
if context in list:
self.port = list.index(context)
self.ser.setPort(self.port)
print self.port
def ChoiceBaudrate(self,event):
self.baudrate = self.boxValueBaudrate.get()
self.ser.setBaudrate(self.baudrate)
print self.baudrate
def Submit(self):
context1 = self.input.get()
n = self.ser.write(context1)
output = self.ser.read(n)
print output
self.show.delete(0.0,END)
self.show.insert(0.0,output)
def open(self):
self.ser.open()
if self.ser.isOpen() == True:
self.showSerial.delete(0.0,END)
self.showSerial.insert(0.0,"Serial has been opend!")
def close(self):
self.ser.close()
if self.ser.isOpen() == False:
self.showSerial.delete(0.0,END)
self.showSerial.insert(0.0,"Serial has been closed!")
root = Tk()
root.title("Serial GUI")
#root.geometry("3000x4000")
app = GUI(root)
root.mainloop()
来源:https://blog.csdn.net/freedom098/article/details/48211567


猜你喜欢
- 正在看的ORACLE教程是:MySQL安全性指南(3)(转)。 &nb
- 业务说明:此示例脚本作用,包含方法和逻辑:图像读取,图片尺寸读取,重置图片大小,图片等比缩放,图片拼接,图片覆盖与堆叠(子母图)图片展示:单
- 爬取过程:你好,李焕英 短评的URL:https://movie.douban.com/subject/34841067/comments?
- 1 本地包声明包是Go程序的基本单位,所以每个Go程序源代码的开始都是一个包声明:package pkgName这就是包声明,pkgName
- 1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0)
- 一、修改密码1.1 创建修改密码控制器运行命令php artisan make:controller Auth/PasswordContro
- UserWarning: indexing with dtype torch.uint8 is now deprecated, please
- 先给大家介绍下python中random模块random与numpy.random对比:1、random.random():生成[0,1)之
- 我就废话不多说了,直接上代码吧!obj = Obj.objects.get(id=1)print obj.name #此时name的值假定为
- 1.php安装。2.下载redis并编译(最好是在 /usr/local目录下运行该命令)# wget http://download.re
- MySQL、SQL Server和mSQL都是绝佳的SQL工具,可惜,在ASP的环境下你却用不着它们来创建实用的SQL语句。不过,你可以利用
- 本文实例讲述了php实现mysql事务处理的方法。分享给大家供大家参考。具体分析如下:要实现本功能的条件是环境 mysql 5.2 /php
- 一、背景我们项目开发人员写的文档都是markdown文件。对于其它组的同学要进行阅读不是很方便。每次编辑完markdown文件,我都是用软件
- 问题一: 在anconda里面如何创建新的python环境(也就是更换新的python版本)1.先打开anconda软件,创建需要的环境2.
- tk在科学养猪群里问bluerust、scz是否碰上过这个Python坑,示例1:bas = [ 'ba1', 'b
- 本文为大家分享了python利用高阶函数实现剪枝函数的具体代码,供大家参考,具体内容如下案例:  
- 以country.xml为例,内容如下:<?xml version="1.0"?><data>
- 如下所示:fp = open(''test2.txt','w') #打开你要写得文件test2.tx
- 创建数据库CREATE DATABASE 语法用于创建一个数据库。语法: PHP MySQL 函数库中,mysql_query()
- 写在前面python-docx 不支持 doc 文档,一定要注意该点,如果使用 doc 文档,需要提前将其用 Word 相关软件转换为 do