Python蓝牙开发——跨平台蓝牙库bleak

Bleak是一个用于蓝牙通信的跨平台库,它提供了一个简单的接口来连接到蓝牙设备,发现服务,读取和写入特征,监听通知等。

以下是使用Bleak进行蓝牙通信的一些基本示例:

  1. 扫描蓝牙设备:



import asyncio
from bleak import discover
 
async def main():
    devices = await discover()
    for device in devices:
        print(f"Device {device.address} - {device.name}")
 
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
  1. 连接到蓝牙设备并读取特征:



import asyncio
from bleak import BleakClient
 
async def main():
    # 假设设备的MAC地址是'XX:XX:XX:XX:XX:XX'
    async with BleakClient("XX:XX:XX:XX:XX:XX") as client:
        # 假设特征的UUID是'00002A19-0000-1000-8000-00805F9B34FB'
        result = await client.read_gatt_char("00002A19-0000-1000-8000-00805F9B34FB")
        print(result)
 
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
  1. 连接到蓝牙设备并写入特征:



import asyncio
from bleak import BleakClient
 
async def main():
    # 假设设备的MAC地址是'XX:XX:XX:XX:XX:XX'
    async with BleakClient("XX:XX:XX:XX:XX:XX") as client:
        # 假设特征的UUID是'00002A19-0000-1000-8000-00805F9B34FB'
        await client.write_gatt_char("00002A19-0000-1000-8000-00805F9B34FB", bytearray([0x01]))
 
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
  1. 连接到蓝牙设备并监听特征通知:



import asyncio
from bleak import BleakClient
 
async def handle_notifications(sender, data):
    print(f"Notification received: {data}")
 
async def main():
    # 假设设备的MAC地址是'XX:XX:XX:XX:XX:XX'
    async with BleakClient("XX:XX:XX:XX:XX:XX") as client:
        # 假设特征的UUID是'00002A19-0000-1000-8000-00805F9B34FB'
        await client.start_notify("00002A19-0000-1000-8000-00805F9B34FB", handle_notifications)
        await asyncio.sleep(10.0)  # 监听一段时间
        await client.stop_notify("00002A19-0000-1000-8000-00805F9B34FB")
 
loop = asyncio.get_event_loop()
loop.run_until_complete(main())

以上代码都是使用async/await语法,这是在Python中编写异步代码的推荐方式。这些例子都是基于假设的设备MAC地址和特征UUID,您需要根据实际的蓝牙设备进行相应的替换。

最后修改于:2024年08月19日 21:53

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日