基于python编写一个串口数据输出程序

 更新时间:2025年10月24日 10:14:05   作者:Love丶伊卡洛斯  
这篇文章主要为大家详细介绍了如何基于python编写一个串口数据输出程序,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以了解下

前言

开发起因

串口调试工具,在串口断开后需要重新选择进行连接,这个过程会耗费一定的时间,而我们的模块上电就开始打印各种日志,导致部分日志丢失。所以就有了这个程序

功能介绍

基于python3实现监听指定端口,获取串口打印数据存入log.txt文件,并自动重连。

开发环境

  • 操作系统:win10
  • 语言:python3.8.15
  • 编辑器:VS Code
  • 依赖库:pyserial (pip install pyserial)

项目地址

github gitee

目录结构

  • config.json (配置文件)
  • log.txt (日志文件)
  • main.exe (编译打包好的程序)
  • main.py (程序源码)
  • package.json (程序打包的相关配置 auto-py-to-exe)

使用

1.配置

自行修改为合适的配置即可。

{
    // 连接的串口名
    "serial_port": "COM17",
    // 波特率
    "serial_baudrate": 115200,
    // 断开连接后的重连间隔(s),太短电脑可能会蓝屏,注意!
    "interval_time": 1
}

2.运行

双击main.exe即可。或搭建环境,运行 python main.py

源码

config.json

{
    "serial_port": "COM17",
    "serial_baudrate": 115200,
    "interval_time": 1
}

main.py (外置配置版)

# 开发起因:串口调试工具,在串口断开后需要重新选择进行连接,这个过程会耗费一定的时间,而我们的模块上电就开始打印各种日志,导致部分日志丢失。所以就有了这个程序
# 开发环境 py3.8
# 依赖库 pyserial
import serial as pyserial
import time
from datetime import datetime
import sys
import json

# 连接的串口名
serial_port = 'COM17'
# 波特率
serial_baudrate = 115200
# 断开连接后的重连间隔(s),太短电脑可能会蓝屏,注意!
interval_time = 1

# 打开本地文件
with open('config.json', 'r', encoding='utf-8') as f:
    # 通过load方法将文件内容读入到字典中
    data = json.load(f)

try:
    serial_port = data['serial_port']
    serial_baudrate = data['serial_baudrate']
    interval_time = data['interval_time']
    print("[当前配置]\n串口名:{}\n波特率:{}\n重连间隔(s):{}".format(serial_port, serial_baudrate, interval_time))
    f.close()
except Exception as e:
    print(e)
    print("解析config.json出错,请检查配置是否正确")
    sys.exit()

def get_current_date_string(format="%Y-%m-%d"):
    """返回当前日期的字符串表示形式,格式为 YYYY-MM-DD"""
    return datetime.today().strftime(format)

while True:
    try:
        ser = pyserial.Serial(serial_port, serial_baudrate)
        if ser.isOpen():
            print("串口已连接")
            break
    except pyserial.SerialException:
        print("串口连接失败,请检查串口是否正确连接")
        time.sleep(interval_time)

while True:
    try:
        # 忽略无法解码的字节
        data = ser.readline().decode('utf-8', 'ignore')
        print(data)
        file_path = "log-" + get_current_date_string() + ".txt"
        # 日志写入本地
        with open(file_path, 'a') as f:
            f.write(data)
        f.close()
    except pyserial.SerialException:
        print("串口断开,正在尝试重新连接", end="")
        while True:
            try:
                ser = pyserial.Serial(SERIAL_PORT, SERIAL_BAUDRATE)
                if ser.isOpen():
                    print("\n串口已重新连接")
                    break
            except pyserial.SerialException:
                print(".", end="", flush=True)
                time.sleep(interval_time)

com_loop_link.py (写死版)

# 开发起因:串口调试工具,在串口断开后需要重新选择进行连接,这个过程会耗费一定的时间,而我们的模块上电就开始打印各种日志,导致部分日志丢失。所以就有了这个程序
# 开发环境 py3.8
# 依赖库 pyserial
import serial as pyserial
import time

# 连接的串口名
SERIAL_PORT = 'COM17'
# 波特率
SERIAL_BAUDRATE = 115200
# 断开连接后的重连间隔,太短电脑可能会蓝屏,注意!
sleep_time = 1

while True:
    try:
        ser = pyserial.Serial(SERIAL_PORT, SERIAL_BAUDRATE)
        if ser.isOpen():
            print("串口已连接")
            break
    except pyserial.SerialException:
        print("串口连接失败,请检查串口是否正确连接")
        time.sleep(sleep_time)

while True:
    try:
        # 忽略无法解码的字节
        data = ser.readline().decode('utf-8', 'ignore')
        print(data)
        # 日志写入本地
        with open('log.txt', 'a') as f:
            f.write(data)
    except pyserial.SerialException:
        print("串口断开,正在尝试重新连接", end="")
        while True:
            try:
                ser = pyserial.Serial(SERIAL_PORT, SERIAL_BAUDRATE)
                if ser.isOpen():
                    print("\n串口已重新连接")
                    break
            except pyserial.SerialException:
                print(".", end="", flush=True)
                time.sleep(sleep_time)

到此这篇关于基于python编写一个串口数据输出程序的文章就介绍到这了,更多相关python串口数据输出程序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python解析yaml文件过程详解

    python解析yaml文件过程详解

    这篇文章主要介绍了python解析yaml文件过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • 利用Python程序读取Excel创建折线图

    利用Python程序读取Excel创建折线图

    这篇文章主要介绍了利用Python程序读取Excel创建折线图,文章通过围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • python实现逐个读取txt字符并修改

    python实现逐个读取txt字符并修改

    今天小编就为大家分享一篇python实现逐个读取txt字符并修改,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • 关于如何使用python的logging库

    关于如何使用python的logging库

    这篇文章主要介绍了关于如何使用python的logging库,logging是Python标准库中用于记录日志的模块。它提供了一种简单但灵活的方法来记录程序中的事件,以便稍后进行调试和分析,需要的朋友可以参考下
    2023-04-04
  • 用python进行视频剪辑

    用python进行视频剪辑

    这篇文章主要介绍了如何用python进行视频剪辑,帮助大家更好的利用python处理视频,感兴趣的朋友可以了解下
    2020-11-11
  • python yield和Generator函数用法详解

    python yield和Generator函数用法详解

    这篇文章主要介绍了python yield和Generator函数用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Python3实现爬取简书首页文章标题和文章链接的方法【测试可用】

    Python3实现爬取简书首页文章标题和文章链接的方法【测试可用】

    这篇文章主要介绍了Python3实现爬取简书首页文章标题和文章链接的方法,结合实例形式分析了Python3基于urllib及bs4库针对简书网进行文章抓取相关操作技巧,需要的朋友可以参考下
    2018-12-12
  • python神经网络Keras构建CNN网络训练

    python神经网络Keras构建CNN网络训练

    这篇文章主要为大家介绍了python神经网络学习使用Keras构建CNN网络训练,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • python获取文件路径、文件名、后缀名的实例

    python获取文件路径、文件名、后缀名的实例

    下面小编就为大家分享一篇python获取文件路径、文件名、后缀名的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04
  • python+selenium自动化实战携带cookies模拟登陆微博

    python+selenium自动化实战携带cookies模拟登陆微博

    这篇文章主要介绍了python+selenium自动化实战携带cookies模拟登陆微博,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01

最新评论