婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python中使用matplotlib繪制mqtt數據實時圖像功能

Python中使用matplotlib繪制mqtt數據實時圖像功能

熱門標簽:哈爾濱外呼系統代理商 電話機器人適用業務 鄭州智能外呼系統運營商 獲客智能電銷機器人 不錯的400電話辦理 湛江電銷防封卡 徐州天音防封電銷卡 南昌辦理400電話怎么安裝 佛山防封外呼系統收費

效果圖

mqtt發布

本代碼中publish是一個死循環,數據一直往外發送。

import random
import time
from paho.mqtt import client as mqtt_client
import json
from datetime import datetime

broker = 'broker.emqx.io'
port = 1883
topic = "/python/mqtt/li"
client_id = f'python-mqtt-{random.randint(0, 1000)}'  # 隨機生成客戶端id


def connect_mqtt():
    def on_connect(client, userdata, flags, rc):
        if rc == 0:
            print("Connected to MQTT Broker!")
        else:
            print("Failed to connect, return code %d\n", rc)

    client = mqtt_client.Client(client_id)
    client.on_connect = on_connect
    client.connect(broker, port)
    return client


def publish(client):
    while True:
        time.sleep(0.01)
        msg = json.dumps({"MAC": "0123456789",
                          "samplerate": 12,
                          "sampletime": str(datetime.utcnow().strftime('%Y/%m/%d-%H:%M:%S.%f')[:-3]),
                          "battery": 0.5,
                          "acc": [
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                              [random.randint(200, 350), -random.randint(200, 350), -random.randint(200, 350), random.randint(200, 350), random.randint(200, 350), random.randint(200, 350)],
                          ]})
        result = client.publish(topic, msg)
        status = result[0]
        if status == 0:
            print(f"Send `{msg}` to topic `{topic}`")
        else:
            print(f"Failed to send message to topic {topic}")


def run():
    client = connect_mqtt()
    client.loop_start()
    publish(client)


if __name__ == '__main__':
    run()

mqtt訂閱

from paho.mqtt import client as mqtt_client
import time
import os

broker = 'broker.emqx.io'
port = 1883
topic = "/python/mqtt/li"

def connect_mqtt(client_id):
    """    MQTT 連接函數。    """
    def on_connect(client, userdata, flags, rc):
        """
        連接回調函數
        在客戶端連接后被調用,在該函數中可以依據 rc 來判斷客戶端是否連接成功。
        """
        if rc == 0:
            print("Connected to MQTT Broker! return code %d" % rc)
        else:
            print("Failed to connect, return code %d\n", rc)

    client = mqtt_client.Client(client_id)
    # client.username_pw_set('uname', 'upwd')  # 鏈接mqtt所需的用戶名和密碼,沒有可不寫
    client.on_connect = on_connect
    client.connect(broker , port)
    return client


def subscribe(client: mqtt_client, a_topic):
    """     訂閱消息       """
    def on_message(client, userdata, msg):
        """
        消息回調函數
        在客戶端從 MQTT Broker 收到消息后被調用,在該函數中我們將打印出訂閱的 topic 名稱以及接收到的消息內容。
         * 這里可添加自定義數據處理程序
        """
        print('From topic : %s\n\tmsg : %s' % (msg.topic, msg.payload.decode()))

    client.subscribe(topic)
    client.on_message = on_message


def run(client_id, topic):
    client = connect_mqtt(client_id)
    subscribe(client, topic)
    client.loop_forever()

if __name__ == '__main__':
    run('test_eartag-003-python-li', 'zk100/gw/#')

matplotlib繪制動態圖

import matplotlib.pyplot as plt
import numpy as np

count = 100  # 圖中最多數據量

ax = list(range(count))  # 保存圖1數據
ay = [0] * 100
bx = list(range(count))  # 保存圖2數據
by = [0] * 100
num = count  # 計數

plt.ion()  # 開啟一個畫圖的窗口進入交互模式,用于實時更新數據
plt.rcParams['figure.figsize'] = (10, 10)  # 圖像顯示大小
plt.rcParams['font.sans-serif'] = ['SimHei']  # 防止中文標簽亂碼,還有通過導入字體文件的方法
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['lines.linewidth'] = 0.5  # 設置曲線線條寬度
plt.tight_layout()
while True:
    plt.clf()  # 清除刷新前的圖表,防止數據量過大消耗內存
    plt.suptitle("總標題", fontsize=30)  # 添加總標題,并設置文字大小
    g1 = np.random.random()  # 生成隨機數畫圖
    # 圖表1
    ax.append(num)  # 追加x坐標值
    ay.append(g1)  # 追加y坐標值
    agraphic = plt.subplot(2, 1, 1)
    agraphic.set_title('子圖表標題1')  # 添加子標題
    agraphic.set_xlabel('x軸', fontsize=10)  # 添加軸標簽
    agraphic.set_ylabel('y軸', fontsize=20)
    plt.plot(ax[-count:], ay[-count:], 'g-')  # 等于agraghic.plot(ax,ay,'g-')
    # 圖表2
    bx.append(num)
    by.append(g1)
    bgraghic = plt.subplot(2, 1, 2)
    bgraghic.set_title('子圖表標題2')
    bgraghic.plot(bx[-count:], by[-count:], 'r^')

    plt.pause(0.001)  # 設置暫停時間,太快圖表無法正常顯示
    num = num + 1

matplotlib繪制mqtt數據實時圖像

  • 單線程

先啟動mqtt訂閱服務
mqtt訂閱中有阻塞,更新數據后因訂閱服務沒有結束,導致繪圖程序無法繪圖
先啟動繪圖程序
繪圖程序本身也是個循環,拿不到mqtt的實時數據,圖像無法更新

  • 兩個服務加入協程,也不行。具體原因還不知道,容后補充。
  • mqtt作為線程啟動,可解決上述問題
import json
import random
from paho.mqtt import client as mqtt_client
import time
import datetime
from math import ceil, floor
import matplotlib.pyplot as plt
import _thread

# 公共變量
broker = 'broker.emqx.io'
topic = "/python/mqtt/li"
port = 1883
client_id = f'python-mqtt-li-{random.randint(0, 100)}'

show_num = 300

x_num = [-1]  # 計數
acc1 = []
acc2 = []
acc3 = []
acc4 = []
acc5 = []
acc6 = []
stime = []


"""mqtt subscribe topic"""
def str_microsecond_datetime2int_13timestamp(str_microsecond_datetime):
    """將字符串型【毫秒級】格式化時間 轉為 【13位】整型時間戳"""
    datetime_obj = datetime.datetime.strptime(str_microsecond_datetime, "%Y/%m/%d-%H:%M:%S.%f")
    obj_stamp = int(time.mktime(datetime_obj.timetuple()) * 1000.0 + datetime_obj.microsecond / 1000.0) / 1000.0
    return obj_stamp


def int2datetime(int_float_timestamp):
    """
    有小數點:分離小數點,整數轉為格式化時間,小數點直接跟在后面
    無小數點:從第10位進行分離,
    所以本函數只適用于時間戳整數位數大于9且小于11.
    """
    if '.' in str(int_float_timestamp):
        int_float = str(int_float_timestamp).split('.')
        date = time.localtime(int(int_float[0]))
        tempDate = time.strftime("%Y/%m/%d-%H:%M:%S", date)
        secondafter = '.' + str(int_float[1])
        return str(tempDate) + secondafter


def parse_mqttmsg(msg):
    """解析mqt頭數據   MAC samplerate sampletime battery acc"""
    content = json.loads(msg.payload.decode())
    span = 1000 / content['samplerate'] * 10
    time_span = [ceil(span) / 10 / 1000, floor(span) / 10 / 1000]
    sampletime = content['sampletime']
    sampletime_int = str_microsecond_datetime2int_13timestamp(sampletime)
    acc = content['acc']
    for i in range(len(acc)):
        x_num.append(x_num[-1] + 1)
        acc1.append(acc[i][0])
        acc2.append(acc[i][1])
        acc3.append(acc[i][2])
        acc4.append(acc[i][3])
        acc5.append(acc[i][4])
        acc6.append(acc[i][5])
        if i != 0:
            sampletime_int += time_span[i % 2]
            stime.append(int2datetime(round(sampletime_int * 1000, 0) / 1000))
        else:
            stime.append(sampletime)
        print(x_num[-1], stime[-1], acc1[-1], acc2[-1], acc3[-1], acc4[-1], acc5[-1], acc6[-1])


def connect_mqtt():
    def on_connect(client, userdata, flags, rc):
        if rc == 0:
            print("Connected to MQTT Broker!")
        else:
            print("Failed to connect, return code %d\n", rc)
            pass

    client = mqtt_client.Client(client_id)
    client.on_connect = on_connect
    client.connect(broker, port)
    return client


def subscribe(client: mqtt_client):
    def on_message(client, userdata, msg):
        # print(f"Received `{msg.payload.decode()}` from `{msg.topic}` topic")
        parse_mqttmsg(msg)

    client.subscribe(topic)
    client.on_message = on_message


def run():
    client = connect_mqtt()
    subscribe(client)
    client.loop_forever()


""" draw figures """
def draw_figure():
    plt.ion()  # 開啟一個畫圖的窗口進入交互模式,用于實時更新數據
    plt.rcParams['figure.figsize'] = (10, 10)  # 圖像顯示大小
    plt.rcParams['font.sans-serif'] = ['SimHei']  # 防止中文標簽亂碼,還有通過導入字體文件的方法
    plt.rcParams['axes.unicode_minus'] = False
    plt.rcParams['lines.linewidth'] = 0.5  # 設置曲線線條寬度


    count = 0
    while True:
        plt.clf()  # 清除刷新前的圖表,防止數據量過大消耗內存
        plt.suptitle("總標題", fontsize=30)  # 添加總標題,并設置文字大小
        plt.tight_layout()

        # 圖表1
        agraphic = plt.subplot(2, 1, 1)
        agraphic.set_title('子圖表標題1')  # 添加子標題
        agraphic.set_xlabel('x軸', fontsize=10)  # 添加軸標簽
        agraphic.set_ylabel('y軸', fontsize=20)
        plt.plot(x_num[1:][-show_num:], acc1[-show_num:], 'g-')
        try:
            xtricks = list(range(len(acc1) - show_num, len(acc1), 10))  # **1**
            xlabels = [stime[i] for i in xtricks]  # **2**
            plt.xticks(xtricks, xlabels, rotation=15)
        except:
            pass

        # 圖表2
        bgraghic = plt.subplot(2, 1, 2)
        bgraghic.set_title('子圖表標題2')
        bgraghic.set_xlabel('x軸', fontsize=10)  # 添加軸標簽
        bgraghic.set_ylabel('y軸', fontsize=20)
        bgraghic.plot(x_num[1:][-show_num:], acc2[-show_num:], 'r^')

        plt.pause(0.001)  # 設置暫停時間,太快圖表無法正常顯示
        count = count + 1


if __name__ == '__main__':
    # 多線程
    _thread.start_new_thread(run, ())
    draw_figure()

到此這篇關于Python中使用matplotlib繪制mqtt數據實時圖像的文章就介紹到這了,更多相關matplotlib繪制mqtt數據實時圖像內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python使用matplotlib顯示圖像失真的解決方案
  • Python matplotlib畫圖時圖例說明(legend)放到圖像外側詳解
  • python matplotlib包圖像配色方案分享
  • python/Matplotlib繪制復變函數圖像教程
  • Python 用matplotlib畫以時間日期為x軸的圖像
  • Python使用matplotlib模塊繪制圖像并設置標題與坐標軸等信息示例

標簽:廣西 吉安 安康 懷化 蘭州 呂梁 蕪湖 紹興

巨人網絡通訊聲明:本文標題《Python中使用matplotlib繪制mqtt數據實時圖像功能》,本文關鍵詞  Python,中,使用,matplotlib,繪制,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python中使用matplotlib繪制mqtt數據實時圖像功能》相關的同類信息!
  • 本頁收集關于Python中使用matplotlib繪制mqtt數據實時圖像功能的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产激情视频一区二区三区欧美| 色婷婷综合久久久久中文一区二区 | 日韩一区在线免费观看| 欧美做爰猛烈大尺度电影无法无天| 日韩美女一区二区三区四区| 亚洲第一搞黄网站| eeuss鲁一区二区三区| 久久久久国产精品免费免费搜索| 亚洲人吸女人奶水| 国产乱子伦一区二区三区国色天香| 国产天堂亚洲国产碰碰| 国产一区二区精品久久99| 精品国产一区二区三区不卡| 亚洲午夜久久久久久久久电影院 | 丝袜美腿成人在线| 国产欧美日韩另类一区| 亚洲免费在线观看视频| 亚洲色图19p| 亚洲成av人片www| 国产一区二区成人久久免费影院| 国产成人a级片| 欧美顶级少妇做爰| 国产精品女主播在线观看| 亚洲a一区二区| 波多野结衣欧美| 欧美久久久久久蜜桃| 国产一区二区按摩在线观看| 国产成人午夜精品影院观看视频 | 欧美中文字幕不卡| 91久久线看在观草草青青| 国产日韩影视精品| 日韩视频免费直播| 久久国产乱子精品免费女| 亚洲综合清纯丝袜自拍| 最新热久久免费视频| 日韩欧美国产精品一区| 亚洲三级在线免费| 日韩成人一级大片| 欧洲av在线精品| 国产一区二区三区免费观看| 亚洲午夜精品在线| 亚洲制服丝袜在线| 一区二区三区四区在线| 亚洲一区二三区| 日韩毛片在线免费观看| 国产午夜精品一区二区 | 亚洲一区在线观看网站| 一区在线观看视频| 国产精品第一页第二页第三页| 久久日一线二线三线suv| 欧美三级中文字| 91国偷自产一区二区使用方法| 欧美xxxx在线观看| 久久久国产精华| 国产一区不卡在线| 制服丝袜中文字幕一区| 最新热久久免费视频| 午夜成人在线视频| 亚洲一区二区成人在线观看| 日本午夜一区二区| 一区二区三区在线免费视频| 国产精品二三区| 日韩欧美中文字幕制服| 亚洲视频在线一区观看| 中文字幕一区在线观看| 欧美大白屁股肥臀xxxxxx| 精品毛片乱码1区2区3区| 亚洲美女一区二区三区| 亚洲色图19p| 色综合天天综合色综合av | 国产麻豆视频一区二区| 亚洲综合图片区| 五月综合激情日本mⅴ| 国产精品盗摄一区二区三区| 日韩一级黄色大片| 欧美高清视频在线高清观看mv色露露十八 | 色综合天天综合网天天狠天天| 欧美精品色一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了| 在线播放/欧美激情| 69成人精品免费视频| 免费国产亚洲视频| 亚洲成人黄色影院| 香蕉乱码成人久久天堂爱免费| 国产色综合一区| 成人精品视频网站| 久久99久久99| 一区二区免费在线播放| 久久精品视频一区| 欧美在线一区二区三区| 亚洲激情男女视频| 成人激情综合网站| 欧美日韩一区三区| 麻豆一区二区99久久久久| 久久精品人人做人人爽97| av成人免费在线| 五月婷婷综合网| 精品国产乱码久久久久久老虎| 日本韩国精品在线| 日韩一区二区在线看片| 精品国产百合女同互慰| 日韩久久免费av| 国产精品国产自产拍高清av| 中文乱码免费一区二区| 中文字幕精品一区二区精品绿巨人 | 欧美日韩国产免费一区二区 | 91久久精品午夜一区二区| 中文字幕佐山爱一区二区免费| 亚洲桃色在线一区| 国产乱对白刺激视频不卡| 欧美久久久久久久久久| 亚洲激情中文1区| 亚洲成人av在线电影| 亚洲综合一二三区| 色婷婷一区二区三区四区| 91麻豆精品国产91久久久久久| 国产日韩欧美综合在线| 亚洲一区二区av电影| 亚洲图片欧美视频| 国产成人a级片| 色久综合一二码| 久久久精品免费观看| 91蜜桃在线免费视频| 一区二区三区四区蜜桃| 久久精品男人天堂av| 在线不卡a资源高清| av一区二区久久| 国产99久久久精品| 国模无码大尺度一区二区三区| 日韩黄色一级片| 首页国产欧美久久| 欧美成人aa大片| 成人小视频在线| 午夜精品爽啪视频| 88在线观看91蜜桃国自产| 亚洲国产精品久久久男人的天堂| 国产精品久久久久久久久果冻传媒 | 18成人在线视频| 国内不卡的二区三区中文字幕 | 中文字幕 久热精品 视频在线| 精品一区免费av| 久久久久久久久蜜桃| 欧美日韩一区精品| 成人不卡免费av| 国产精品一线二线三线精华| 国产精品毛片a∨一区二区三区| 麻豆精品久久久| 在线观看亚洲精品视频| 亚洲同性gay激情无套| 日本不卡在线视频| 欧美电影一区二区| 国产日本欧洲亚洲| 国产xxx精品视频大全| 高清不卡在线观看av| 高清国产一区二区三区| av一区二区三区四区| 欧美一二三区在线观看| 久久香蕉国产线看观看99| 欧美日韩国产大片| 日本乱人伦aⅴ精品| 欧美少妇一区二区| 91麻豆精品91久久久久久清纯| 欧美三级三级三级爽爽爽| 欧美三级在线看| 久久久久国产精品人| 欧美aa在线视频| 一本大道综合伊人精品热热 | 蜜臀av性久久久久蜜臀aⅴ流畅| 奇米色777欧美一区二区| 国产99久久久国产精品潘金| 99视频国产精品| 国产精品麻豆视频| 一区二区三区免费观看| 日韩成人精品在线| 成人听书哪个软件好| 3atv一区二区三区| 国产精品美日韩| 日韩av中文在线观看| 成人综合在线视频| 911精品产国品一二三产区| 国产欧美日韩视频在线观看| 亚洲成人午夜影院| 国产高清亚洲一区| 91精品午夜视频| 一区在线观看视频| 国内精品视频666| 欧美日韩亚洲高清一区二区| 久久婷婷色综合| 亚洲综合视频在线观看| 国产99久久久国产精品潘金 | 欧美电影免费观看高清完整版| 中文字幕欧美日韩一区| 日韩1区2区日韩1区2区| 91在线观看美女| 久久在线观看免费| 青青草伊人久久| 欧美视频在线观看一区| 成人欧美一区二区三区白人 | 久久久精品蜜桃| 琪琪久久久久日韩精品|