api 查找串口

使用PySerial库调用serial.tools.list_ports.list_ports(),遍历返回的串口对象列表,提取设备名称、描述

API 查找串口的详细实现

串口(Serial Port)是计算机与外部设备通信的重要接口,通过编程接口(API)查找系统中可用的串口,可以实现自动化设备检测、动态端口分配等功能,不同操作系统提供的API和实现方式有所不同。

api 查找串口


Windows 系统下查找串口

使用 SetupDiGetClassDevs 函数

Windows 通过 SetupAPI 提供串口设备枚举功能。

关键步骤:
  1. 初始化 GUID 为串口设备类。
  2. 调用 SetupDiGetClassDevs 获取设备信息集合。
  3. 遍历设备信息列表,提取串口名称(如 COM1)。
代码示例(C++):
#include <windows.h>
#include <setupapi.h>
#include <stdio.h>
void ListSerialPorts() {
    GUID classGuid = GUID_DEVCLASS_PORTS; // 串口设备类 GUID
    HDEVINFO hDevInfo = SetupDiGetClassDevs(&classGuid, NULL, NULL, DIGCF_PRESENT);
    if (hDevInfo == INVALID_HANDLE_VALUE) {
        printf("Failed to get device list.
");
        return;
    }
    SP_DEVINFO_DATA devInfoData;
    devInfoData.cbSize = sizeof(SP_DEVINFO_DATA);
    int index = 0;
    while (SetupDiEnumDeviceInfo(hDevInfo, index, &devInfoData)) {
        index++;
        // 获取设备描述大小
        DWORD regDataSize;
        SetupDiGetDeviceRegistryProperty(hDevInfo, &devInfoData, SPDRP_FRIENDLYNAME, &regDataSize, NULL, 0);
        char* buffer = new char[regDataSize];
        SetupDiGetDeviceRegistryProperty(hDevInfo, &devInfoData, SPDRP_FRIENDLYNAME, &regDataSize, buffer, regDataSize);
        printf("Found Port: %s
", buffer);
        delete[] buffer;
    }
    SetupDiDestroyDeviceInfoList(hDevInfo);
}
输出示例:
Found Port: COM1
Found Port: COM2

Linux 系统下查找串口

读取 /dev/serial/by-path 目录

Linux 系统将串口设备以符号链接形式存放在 /dev/serial/by-path 目录下。

关键步骤:
  1. 打开 /dev/serial/by-path 目录。
  2. 读取所有符号链接,解析目标文件名(如 /dev/ttyS0)。
  3. 去重后输出串口列表。
代码示例(Python):
import os
def list_serial_ports():
    serial_path = "/dev/serial/by-path"
    if not os.path.exists(serial_path):
        print("No serial ports found.")
        return []
    ports = set()
    for file in os.listdir(serial_path):
        target = os.readlink(os.path.join(serial_path, file))
        ports.add(os.path.basename(target))
    return sorted(ports)
if __name__ == "__main__":
    ports = list_serial_ports()
    for port in ports:
        print(f"Found Port: {port}")
输出示例:
Found Port: ttyS0
Found Port: ttyUSB0

跨平台实现对比

特性 Windows Linux
API 核心函数 SetupDiGetClassDevs os.listdir + os.readlink
设备信息来源 注册表(Registry) /dev/serial/by-path 目录
权限要求 普通用户可访问 需要 root 权限或拨号组(dialout)
输出格式 设备描述(如 COM1 设备文件名(如 ttyS0

相关问题与解答

问题 1:如何判断某个串口是否被其他程序占用?

解答

api 查找串口

  • Windows:尝试用 CreateFile 打开串口,若返回 ERROR_ACCESS_DENIEDERROR_SHARING_VIOLATION,则表示被占用。
  • Linux:尝试用 open() 打开设备文件,若返回 EBUSYEACCES,则表示被占用。
    示例

    # Linux 检查 ttyS0 是否被占用
    try:
      fd = open("/dev/ttyS0", "r+b")
      fd.close()
      print("Port is free.")
    except OSError as e:
      print(f"Port is busy or unavailable: {e}")

问题 2:如何通过 API 获取串口的硬件信息(如厂商、型号)?

解答

  • Windows:使用 SetupDiGetDeviceRegistryProperty 获取 SPDRP_MFG(厂商)和 SPDRP_DEVICEDESC(设备描述)。
  • Linux:读取 /sys/class/tty/ttyS0/device/manufacturer/sys/class/tty/ttyS0/device/product 文件。
    示例

    # Linux 获取 ttyS0 的厂商和型号
    with open("/sys/class/tty/ttyS0/device/manufacturer") as f:
      manufacturer = f.read().strip()
    with open("/sys/class/tty/ttyS0/device/product") as f:
      product = f.read().strip()
    print(f"Manufacturer: {manufacturer}, Product: {product}")

涵盖了不同操作系统下通过 API 查找串口的实现

到此,以上就是小编对于“api 查找串口”的问题就介绍到这了,希望介绍的几点解答对大家有用,有任何问题和不懂的,欢迎各位朋友在评论区讨论,给我留言。

api 查找串口

【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!

(0)
热舞的头像热舞
上一篇 2025-05-13 03:24
下一篇 2025-05-13 03:34

相关推荐

  • 负载均衡与高可用性(HA)之间有何关联与区别?

    负载均衡与高可用性(HA)是现代网络和计算系统中不可或缺的两个重要概念,它们各自有着独特的作用和应用场景,下面将详细介绍这两个概念的定义、区别以及在实际应用中的实现方法:一、负载均衡概述1、定义:负载均衡是一种技术解决方案,用来在多个资源中分配负载,达到优化资源使用,避免过载的目的,它通过将用户请求分发到多台服……

    2024-11-09
    00156
  • 服务器重启后,为什么WDCP无法进入?

    1、文件格式问题:在处理文件时,如果发现文件是DOS格式(即Windows系统下创建的文件),需要将其转换为Unix格式,这是因为Linux系统默认使用Unix格式,而Windows系统则使用DOS格式,可以通过命令set ff=unix来设置文件格式为Unix,然后保存并退出编辑器,2、服务未启动:在服务器重……

    2024-12-15
    005
  • 服务器配置与管理简答题答案,如何高效掌握关键知识点?

    服务器配置与管理简答题答案服务器配置与管理是信息技术领域中至关重要的一部分,它涉及到硬件、软件以及网络环境的设置和维护,以下是一些常见的服务器配置与管理的简答题及其答案:1、什么是服务器?答案:服务器是一种高性能的计算机,用于存储、处理和传输数据,为客户端提供各种服务,它可以是物理服务器或虚拟服务器,运行在数据……

    2024-11-29
    0014
  • 如何通过服务器配置公众号提升网站性能与用户体验?

    服务器配置公众号背景介绍微信公众号作为一款广泛使用的社交软件,已经成为企业和个人进行品牌推广和用户互动的重要平台,开发一个功能齐全的公众号,需要对微信公众号平台的API文档有深入的了解,并且能够正确配置服务器以处理微信的消息和事件,本文将详细介绍如何配置微信公众号的服务器,包括前期准备、具体步骤以及代码示例,前……

    2024-11-07
    003

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

广告合作

QQ:14239236

在线咨询: QQ交谈

邮件:asy@cxas.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信