当前位置: 首页 > news >正文

WPF调用Python心率监测脚本解决方案

一、项目背景

你有一个Python脚本PolarHR.py,使用bleak库异步扫描并连接蓝牙心率设备,后台线程持续获取心率数据,并每2秒打印最新心率。

你希望在WPF程序中启动该Python脚本,实时获取心率数据并显示。

在这里插入图片描述


二、Python脚本(PolarHR.py)

请确保Python脚本内容如下,重点是:

  • 使用print(..., flush=True)确保输出不被缓冲,WPF能及时读取。
  • 每2秒打印格式为当前心率: 数字的字符串,方便WPF解析。
import asyncio
import threading
from bleak import BleakScanner, BleakClient
import timeHR_UUID = "00002a37-0000-1000-8000-00805f9b34fb"
_latest_heart_rate = None
_lock = threading.Lock()async def _heart_rate_worker():global _latest_heart_rateprint("开始扫描设备...", flush=True)devices = await BleakScanner.discover(timeout=5)print(f"扫描到设备数量: {len(devices)}", flush=True)polar_devices = [d for d in devices if d.name and "Polar" in d.name]print(f"找到 Polar 设备数量: {len(polar_devices)}", flush=True)if not polar_devices:print("未找到 Polar 设备", flush=True)returndevice = polar_devices[0]async with BleakClient(device.address) as client:queue = asyncio.Queue()def callback(sender, data):flags = data[0]hr_format = flags & 0x01if hr_format:hr = int.from_bytes(data[1:3], byteorder='little')else:hr = data[1]queue.put_nowait(hr)await client.start_notify(HR_UUID, callback)print(f"已连接设备 {device.name},开始接收心率数据...", flush=True)while True:hr = await queue.get()with _lock:_latest_heart_rate = hrdef _start_loop(loop):asyncio.set_event_loop(loop)loop.run_until_complete(_heart_rate_worker())def start_heart_rate_monitor():loop = asyncio.new_event_loop()t = threading.Thread(target=_start_loop, args=(loop,), daemon=True)t.start()def get_latest_heart_rate():with _lock:return _latest_heart_rateif __name__ == "__main__":start_heart_rate_monitor()while True:hr = get_latest_heart_rate()if hr is not None:print(f"当前心率: {hr}", flush=True)else:print("当前心率: None", flush=True)time.sleep(2)

三、WPF项目代码示例

1. MainWindow.xaml

<Window x:Class="HeartRateWpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"Title="心率监测" Height="200" Width="300"><Grid><TextBlock x:Name="HeartRateTextBlock" FontSize="24" HorizontalAlignment="Center" VerticalAlignment="Center"/></Grid>
</Window>

2. MainWindow.xaml.cs

using System;
using System.Diagnostics;
using System.Text.RegularExpressions;
using System.Windows;
using System.Windows.Threading;namespace HeartRateWpfApp
{public partial class MainWindow : Window{private Process _pythonProcess;private string _latestHeartRate = null;private DispatcherTimer _timer;public MainWindow(){InitializeComponent();StartPythonProcess();StartTimer();}private void StartPythonProcess(){var psi = new ProcessStartInfo{FileName = @"C:\Path\To\Your\Python\python.exe",  // 替换为你的python.exe完整路径Arguments = "-u PolarHR.py",  // -u 禁用缓冲,PolarHR.py是脚本名WorkingDirectory = @"C:\Users\86730\Desktop\步态资料\步态资料", // 脚本所在目录UseShellExecute = false,RedirectStandardOutput = true,RedirectStandardError = true,CreateNoWindow = true};_pythonProcess = new Process();_pythonProcess.StartInfo = psi;_pythonProcess.OutputDataReceived += PythonOutputDataReceived;_pythonProcess.ErrorDataReceived += PythonErrorDataReceived;_pythonProcess.Start();_pythonProcess.BeginOutputReadLine();_pythonProcess.BeginErrorReadLine();}private void PythonOutputDataReceived(object sender, DataReceivedEventArgs e){if (string.IsNullOrEmpty(e.Data)) return;// 调试输出,方便查看Python打印内容Console.WriteLine("Python STDOUT: " + e.Data);// 匹配格式:当前心率: 数字var match = Regex.Match(e.Data, @"当前心率:\s*(\d+)");if (match.Success){_latestHeartRate = match.Groups[1].Value;}}private void PythonErrorDataReceived(object sender, DataReceivedEventArgs e){if (!string.IsNullOrEmpty(e.Data)){Console.WriteLine("Python STDERR: " + e.Data);}}private void StartTimer(){_timer = new DispatcherTimer();_timer.Interval = TimeSpan.FromSeconds(2);_timer.Tick += Timer_Tick;_timer.Start();}private void Timer_Tick(object sender, EventArgs e){if (string.IsNullOrEmpty(_latestHeartRate)){HeartRateTextBlock.Text = "等待心率数据...";}else{HeartRateTextBlock.Text = $"当前心率: {_latestHeartRate}";}}protected override void OnClosed(EventArgs e){base.OnClosed(e);if (_pythonProcess != null && !_pythonProcess.HasExited){_pythonProcess.Kill();_pythonProcess.Dispose();}}}
}

四、注意事项

  1. 替换Python路径
    FileName中的路径替换为你本机Python解释器的完整路径,例如:

    C:\Users\86730\AppData\Local\Programs\Python\Python310\python.exe
    
  2. 确保Python环境安装依赖
    确保bleak库已安装:

    C:\Path\To\Your\Python\python.exe -m pip install bleak
    
  3. 确保Python脚本路径正确
    WorkingDirectory设置为Python脚本所在目录,Arguments只写脚本名。

  4. 调试输出
    运行WPF程序时,查看输出窗口(Console)是否有Python的标准输出和错误输出,确认Python脚本是否正常启动。

  5. 蓝牙权限
    确保WPF程序有权限访问蓝牙设备,必要时以管理员身份运行。


五、总结

  • Python脚本后台线程持续采集心率数据,主线程每2秒打印格式为当前心率: 数字的字符串。
  • WPF启动Python进程,异步读取标准输出,使用正则表达式匹配并提取数字心率。
  • WPF用DispatcherTimer每2秒刷新UI显示最新心率。

文章转载自:

http://ABZ2VZ6F.kgphd.cn
http://sGfM18Jl.kgphd.cn
http://6Oy1wWhc.kgphd.cn
http://GjZP1KsC.kgphd.cn
http://1EVEZ09V.kgphd.cn
http://kZCmD1Qw.kgphd.cn
http://XYeWF7OQ.kgphd.cn
http://ntJ7vPGA.kgphd.cn
http://7GOBTyQm.kgphd.cn
http://J5UgpI2H.kgphd.cn
http://960T3lty.kgphd.cn
http://LId5rhFz.kgphd.cn
http://WeAOlDgh.kgphd.cn
http://oOUQHd1b.kgphd.cn
http://TNmrHlsI.kgphd.cn
http://LiLBZ6c2.kgphd.cn
http://6UyHQMDC.kgphd.cn
http://hvkTshUW.kgphd.cn
http://QbPJIWE9.kgphd.cn
http://ldCLJWjZ.kgphd.cn
http://Bv4TaxvL.kgphd.cn
http://mG7vF9t4.kgphd.cn
http://VILhWyhy.kgphd.cn
http://X33CiCRB.kgphd.cn
http://uyN35gGy.kgphd.cn
http://cQSGoybS.kgphd.cn
http://qVxsyd70.kgphd.cn
http://nnHWwFe6.kgphd.cn
http://8ahKYoB9.kgphd.cn
http://nptszy0k.kgphd.cn
http://www.dtcms.com/a/245515.html

相关文章:

  • 装饰器模式(Decorator Pattern)
  • K8s 指标收集方案对比
  • 【深尚想】M74VHC1GT08DTT1G逻辑芯片安森美ON 工业/物联网首选 电子元器件解析
  • 基于springboot视频及游戏管理系统+源码+文档
  • Next.js + Supabase = 快速开发 = 高速公路
  • 华为云物联网系统开发(纯云端)外包方案及项目需求说明书
  • 【生产实践】DolphinScheduler集群MySQL数据源切换终极指南|附生产环境避坑手册
  • AbMole| Angiotensin II human(M6240;血管紧张素Ⅱ)
  • 数量关系与资料分析【总结】
  • Android7 Input(十一)App View InputEvent事件分发
  • 全志A33安卓6.0添加支持usb摄像头动态热插拔
  • 【Docker 04】image - 镜像
  • 单片机中面向对象的思维
  • 从零开始学Python(2)——流程控制语句和五种容器
  • 《射频识别(RFID)原理与应用》期末复习 RFID第四章 数据校验和防碰撞算法(知识点总结+习题巩固)
  • js判断手机操作系统(ios、安卓、华为)
  • FastDFS分布式存储
  • web3 资讯网址
  • Web 架构之 Kubernetes 弹性伸缩策略设计
  • 如何将 iPhone 中的短信导出为 PDF
  • C/C++ 面试复习笔记(6)
  • 一[3]、ubuntu18.04环境 利用 yolov8 训练开源列车数据集,并实现列车轨道检测
  • Java基于SpringBoot的牙科诊所管理系统,附源码+文档说明
  • Springboot实现Java程序和线程池的优雅关闭
  • 计算机视觉之三维重建(深入浅出SfM与SLAM核心算法)—— 1. 摄像机几何
  • Oracle DG库手动注册归档日志的两种方法
  • 【报错解决】RTX4090 nvrtc: error: invalid value for --gpu-architecture (-arch)
  • Android 手机操作系统的14个常见问题以及解决办法
  • PostgreSQL认证怎么选?PGCP中级认证、PGCM高级认证
  • Git 常用总结