PyBluez2 的详细介绍、安装指南、使用方法及配置说明

PyBluez2:Python 蓝牙开发的核心库

一、PyBluez2 简介

PyBluez2 是 Python 的开源蓝牙编程库,支持蓝牙 2.0+、BLE(低功耗蓝牙)和传统蓝牙协议栈的开发。它提供了对蓝牙硬件适配器的底层控制,适用于设备发现、配对、数据传输和服务解析等场景。其核心优势包括:

  • 跨平台支持:兼容 Linux、Windows、macOS 系统
  • 协议丰富性:支持 HID、SPP、L2CAP、GATT 等协议
  • 简洁的 API:抽象底层复杂性,提供高层次的蓝牙操作接口
  • 社区驱动:持续更新,修复蓝牙 5.0+ 新特性支持

二、安装指南

1. 系统要求

操作系统版本要求依赖库
LinuxUbuntu 20.04+/Debian 11+bluez >= 5.60
Windows10/11 (64位)Microsoft Bluetooth Stack
macOS10.15+CoreBluetooth.framework

2. 安装步骤

Linux/macOS

# 使用 pip 安装最新版本
pip install pybluez2# 验证安装
python3 -c "import bluetooth; print(bluetooth.__version__)"

Windows

# 下载预编译 wheel 文件(推荐)
https://github.com/pybluez/pybluez2/releases/download/v0.10.2/pybluez2‑0.10.2‑cp310‑cp311‑win_amd64.whl# 安装 wheel 文件
pip install pybluez2‑0.10.2‑cp310‑cp311‑win_amd64.whl

三、基础使用指南

1. 初始化蓝牙适配器

import bluetooth# 获取所有蓝牙适配器名称
adapters = bluetooth.get_available_adapters()
print(f"Available adapters: {adapters}")# 使用第一个适配器(索引从0开始)
adapter_name = adapters[0]
adapter = bluetooth.BluetoothAdapter(adapter_name)
adapter.start()

2. 设备发现

扫描附近设备

devices = adapter.discover_devices()
print(f"Found {len(devices)} devices:")
for addr, name in devices:print(f"  {addr}: {name}")

通过 UUID 过滤设备

uuids = [bluetooth.UUID('1101')]  # HID 服务 UUID
devices = adapter.discover_devices_with_uuids(uuids)
print(f"Found HID devices: {devices}")

3. 建立连接

传统蓝牙 SPP 连接

# 服务 UUID(示例:串口服务)
service_uuid = bluetooth.UUID('00001101')# 查找设备并连接
device_addr = "00:1A:5D:6B:3E:D1"
device = bluetooth.BluetoothDevice(device_addr)
device.connect(service_uuid)# 发送数据
device.send("Hello from PyBluez2!")

BLE 连接(低功耗蓝牙)

# 扫描 BLE 设备
ble_devices = adapter.discover_ble_devices()
print(f"Found {len(ble_devices)} BLE devices.")# 连接设备
device_addr = "00:1A:5D:6B:3E:D1"
device = bluetooth.BluetoothDevice(device_addr)
device.connect()# 发现 GATT 服务
services = device.gatt_discover_services()
print(f"Services: {services}")# 读取特征值
service_uuid = bluetooth.UUID('00002a37')  # 心率特征
characteristic = device.gatt_get_characteristic(service_uuid)
value = characteristic.read()
print(f"Heart Rate: {value.decode('utf-8')}")

四、高级配置

1. 适配器配置

设置蓝牙电源模式

adapter.set_power_mode(bluetooth.PowerMode.POWER_OFF)  # 关闭蓝牙
adapter.set_power_mode(bluetooth.PowerMode.POWER_ON)   # 开启蓝牙

启用发现模式

adapter.start_discovery()
adapter.stop_discovery()

2. BLE 服务开发

定义自定义服务

from bluetooth import UUID, Service, Characteristicclass MyService(Service):uuid = UUID('12345678-1234-5678-1234-56789abcdeff')characteristics = [Characteristic(uuid=UUID('12345678-1234-5678-1234-56789abcdeff01'),properties=['read', 'write'])]

注册服务到适配器

adapter.add_service(MyService())
adapter.start()

3. 数据传输优化

使用 L2CAP 通道

# 创建 L2CAP 通道
channel = adapter.open_l2cap_channel(device_addr, psm=17)
channel.send(b"Data chunk")

五、典型应用场景

1. 蓝牙设备控制

  • 智能家居:控制蓝牙灯泡(发送 RGB 值)
  • 穿戴设备:读取心率/步数数据

2. 工业自动化

  • BLE 传感器网络:采集温度/湿度数据
  • Modbus over BLE:与工业设备通信

3. 物联网网关

  • 多设备聚合:同时连接 10+ BLE 设备并汇总数据

六、常见问题与解决方案

问题现象解决方案
无法发现设备检查蓝牙适配器是否开启并支持 HCI
连接失败确保设备处于配对模式(BLE 需主动配对)
权限不足Linux 下需 sudo 或配置蓝牙权限
蓝牙 5.0 兼容性问题使用最新版本 PyBluez2(>=0.10.0)

七、学习资源

  • 官方文档:https://github.com/pybluez/pybluez2
  • API 参考:PyBluez — PyBluez master documentation
  • 实战案例:https://github.com/pybluez/pybluez2/tree/main/examples

结语
PyBluez2 是 Python 生态中不可或缺的蓝牙开发工具,无论是构建智能家居系统、物联网网关,还是进行蓝牙协议研究,都能提供强大的支持。建议从基础的设备发现和数据传输开始实践,逐步探索 BLE 服务和复杂网络功能。对于企业级应用,可结合 Flask/Django 开发蓝牙 Web 服务。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/41304.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 大视界 -- 基于 Java 的大数据分布式系统的监控与运维实践(155)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

消息队列性能比拼: Kafka vs RabbitMQ

本内容是对知名性能评测博主 Anton Putra Kafka vs RabbitMQ Performance 内容的翻译与整理, 有适当删减, 相关数据和结论以原作结论为准。 简介 在本视频中,我们将首先比较 Apache Kafka 和传统的 RabbitMQ。然后,在第二轮测试中,会将 Kaf…

[ComfyUI] SDXL Prompt Styler 自定义节点的作用解析

1. SDXL Prompt Styler 的位置与基本功能 在 ComfyUI 的 “新建节点” → “实用工具” 下,可以找到 Style 节点(SDXL Prompt Styler)。该节点的主要作用是对输入的描述进行结构化处理,并在转换为 Stable Diffusion XL (SDXL) 提示词时,自动补充风格相关的内容,使提示词…

【JavaScript】金丹期功法

目录 数组声明数组数组的基本使用遍历数组案例:求数组中的最值数组操作查询数据修改数据新增数据案例:数组筛选删除数据 案例:渲染柱形图 数组 数组(Array)是一种可以按顺序保存数据的数据类型 场景:如果…

学习本地部署DeepSeek的过程(基于LM Studio)

除了使用Ollama部署DeepSeek,还可以使用LM Studio部署DeepSeek,后者是一款允许用户在本地计算机上运行大型语言模型(LLMs)的桌面应用程序,旨在简化本地模型的使用,无需云端连接或复杂配置即可体验 AI 功能。…

AOA与TOA混合定位,MATLAB例程,自适应基站数量,三维空间下的运动轨迹,滤波使用EKF

本代码实现了一个基于 到达角(AOA) 和 到达时间(TOA) 的混合定位算法,结合 扩展卡尔曼滤波(EKF) 对三维运动目标的轨迹进行滤波优化。代码通过模拟动态目标与基站网络,展示了从信号测量、定位解算到轨迹滤波的全流程,适用于城市峡谷、室内等复杂环境下的定位研究。 文…

C++:函数(通识版)

一、函数的基础 1.什么是函数?(独立的功能单位) 函数是C中封装代码逻辑的基本单元,用于执行特定任务。 作用:代码复用、模块化、提高可读性。 2、函数的基本结构 返回类型 函数名(参数列表) {// 函数体return 返回值…

STL之map和set

1. 关联式容器 vector、list、deque、 forward_list(C11)等,这些容器统称为序列式容器,因为其底层为线性序列的数据结构,里面存储的是元素本身。 关联式容器也是用来存储数据的,与序列式容器不同的是,其里面存储的是结…

虚拟机(一):Java 篇

虚拟机(一):Java 篇 虚拟机(二):Android 篇 架构 运行时数据区: 栈: 堆: 堆:通过new创建的对象都在堆中分配。OutOfMemoryError TLAB(Thread Local All…

无线安灯按钮盒汽车零部件工厂的故障告警与人员调度专家

在汽车零部件制造领域,生产线故障与物料短缺等问题往往引发连锁反应,导致停机损失与成本激增。传统人工巡检与纸质工单模式已难以满足高效生产需求,而无线安灯按钮盒的智能化应用,正成为破解这一难题的关键利器。 一、精准告警&am…

二叉树相关算法实现:判断子树与单值二叉树

目录 一、判断一棵树是否为另一棵树的子树 (一)核心思路 (二)代码实现 (三)注意要点 二、判断一棵树是否为单值二叉树 (一)核心思路 (二)代码实现…

数据结构初阶-二叉树链式

目录 1.概念与结构 2.二叉数链式的实现 2.1遍历规则 2.2申请内存空间 2.3手动构建一棵二叉树 2.4二叉树结点的个数 2.5二叉树叶子结点的个数 2.6二叉树第K层结点个数 2.7二叉树的高度 2.8二叉树中查找值为x的结点 2.9二叉树的销毁 3.层序遍历 3.1概念 3.2层序遍历…

SpringMVC拦截器

SpringMVC拦截器 什么是拦截器拦截器和过滤器的区别SpringMVC 拦截器的工作原理拦截器的配置拦截器的配置主要有两种方式XML 配置方式Java配置方式 创建一个拦截器拦截器的应用场景拦截器的执行顺序 什么是拦截器 SpringMVC 的拦截器(Interceptor)是指在…

cocos creator 笔记-路边花草

版本:3.8.5 实现目标:给3d道路生成路边景观花草 在场景下创建一个节点,我这里种植两种花草模型,兰花和菊花,所以分别在节点下另创建两个节点,为了静态合批。 1.将花草模型分别拖入场景中,制作…

YoloV8训练和平精英人物检测模型

概述 和平精英人物检测,可以识别游戏中所有人物角色,并通过绘制框将人物选中,训练的模型仅仅具有识别功能,可以识别游戏中的视频、图片等文件,搭配Autox.js可以推理,实现实时绘制,但是对手机性…

达梦改密码时不想看到明文

有时,需要修改用户密码 但不想让别人看到你的密码明文 最简单的是用manager工具 找到用户,点击右键,选择modify 这里很明显被掩盖为黑点了,放心输入即可 想通过命令行怎么办? 这不,密码全被看到了 用变…

3. 轴指令(omron 机器自动化控制器)——>MC_GearInPos

机器自动化控制器——第三章 轴指令 17 MC_GearInPos变量▶输入变量▶输出变量▶输入输出变量 功能说明▶时序图▶重启运动指令▶多重启动运动指令▶异常 示例程序▶动作示例▶梯形图▶结构文本(ST) MC_GearInPos 设定主轴和从轴间的齿轮比,进行电子齿轮动作。 指定…

【教学类-58-14】黑白三角拼图12——单页1页图。参考图1页6张(黑白、彩色)、板式(无圆点、黑圆点、白圆点)、宫格2-10、张数6张,适合集体操作)

背景需求: 基于以下两个代码,设计一个单页1页黑白三角、彩色三角(包含黑点、白点、无点)的代码。 【教学类-58-12】黑白三角拼图10(N张参考图1张操作卡多张彩色白块,适合个别化)-CSDN博客文章…

pytest-xdist 进行高效并行自动化测试

pytest-xdist 的核心功能是通过多进程分发测试任务,每个进程独立运行测试,确保测试隔离。2025 年 3 月 25 日,pytest-xdist 在 GitHub 上已有超过 1,200,000 次下载,表明其在测试社区中的广泛接受。 在自动化测试中,随…

18502 字符串哈希匹配字符串

18502 字符串哈希匹配字符串 ⭐️难度:中等 🌟考点:字符串hash 📖 📚 import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static int…