python 波形图学习(队列+matplotlib)
版本01:使用队列+进程,通过键盘模拟数据的输入,最后打印输入的数据到屏幕中
import multiprocessing
from re import T
# 键盘输入数据函数
def input_data():
data = input("请通过键盘输入模拟发送的数据 : ")
return data
"""
一个进程向Queue中写入数据,另外一个进程从Queue中获取数据,
通过Queue完成了 多个需要配合的进程间的数据共享,从而能够起到解耦的作用
"""
def send_into_quene(q):
"""下载数据"""
# 模拟从网上下载的数据
while True:
# 通过键盘模拟输入发送数据
data = input_data()
q.put(data)
# 向队列中写入数据
if data == "exit":
print("获取到错误的数据,退出主程序")
break
else :
print("---键盘模拟数据写入成功----")
def analysis_data(q):
"""数据接收处理"""
waitting_analysis_data = list()
while True:
# 从队列中获取数据
data = q.get()
# 对队列中的数据进行分析
if data == "exit":
print("接收到 exit, 退出程序")
break
else :
# 将数据添加到列表中
waitting_analysis_data.append(data)
# 打印列表中的数据
print(waitting_analysis_data)
print("---数据接收成功----")
def main():
# 1. 创建一个队列
q = multiprocessing.Queue()
# 2. 创建多个进程,将队列的引用当做实参进行传递到里面
p2 = multiprocessing.Process(target=analysis_data, args=(q,))
p2.start()
# 3、 向队列中写入数据
send_into_quene(q)
if __name__ == "__main__":
main()
版本02: 模型串口快速发送数据,通过使用进程的方式,实时显示波形
from cmath import sin
import matplotlib.pyplot as plt
import numpy as np
import multiprocessing
from re import T