广场气象系统(nle库)

python 复制代码
import sys
from threading import Thread

import requests, time
import matplotlib.pyplot as plt
from nle_library.httpHelp.NetWorkBusiness import NetWorkBusiness

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

wdsj = []
sdsj = []
sjcc = []

A = 10


def login():
    para = dict(Account='15079001133', Password='123456')
    X = requests.post(url='http://api.nlecloud.com/users/login', data=para)
    return X.json()['ResultObj']['AccessToken']


def task():
    global wdsj, sdsj, sjcc
    api = NetWorkBusiness('api.nlecloud.com', 80)
    a = login()
    api.setAccessToken(a)
    while True:

        wd = api.getDeviceSensorHistoryDatas(895940, 'm_temp')
        wd = dict(wd)
        wd = wd['ResultObj']['DataPoints'][0]['PointDTO'][0]['Value']
        wd = float(wd)
        wdsj.append(wd)

        sd = api.getDeviceSensorHistoryDatas(895940, 'm_hum')
        sd = dict(sd)
        sd = sd['ResultObj']['DataPoints'][0]['PointDTO'][0]['Value']
        sd = float(sd)
        sdsj.append(sd)

        sj = time.strftime('%H:%M:%S')
        sjcc.append(sj)

        time.sleep(5)

        if len(sjcc) == 7:
            plt.cla()
            sdsj.pop(0)
            wdsj.pop(0)
            sjcc.pop(0)


def zx():
    global wdsj, sdsj, sjcc
    fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(20, 5))
    ax1.set_title('温度变化图')
    ax1.set_xlabel('时间')
    ax1.set_ylabel('温度值')

    ax2.set_title('湿度变化图')
    ax2.set_xlabel('时间')
    ax2.set_ylabel('湿度值')
    ax1.plot(sjcc, wdsj)
    ax2.plot(sjcc, sdsj, color='r')
    fig.canvas.mpl_connect('close_event', on_cle)

    while True:
        print(wdsj)
        if len(sjcc) == 7:
            ax1.clear()  # 清除子图1的内容
            ax2.clear()  # 清除子图2的内容
            ax1.set_title('温度变化图')
            ax1.set_xlabel('时间')
            ax1.set_ylabel('温度值')

            ax2.set_title('湿度变化图')
            ax2.set_xlabel('时间')
            ax2.set_ylabel('湿度值')

        ax1.plot(sjcc, wdsj)
        ax2.plot(sjcc, sdsj)

        plt.draw()
        plt.pause(10)


def on_cle(self):
    plt.close()
    sys.exit()


if __name__ == '__main__':
    P1 = Thread(target=task)
    P1.setDaemon(True)
    P1.start()
    zx()
相关推荐
B站_计算机毕业设计之家几秒前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
渣渣苏8 分钟前
Langchain实战快速入门
人工智能·python·langchain
3GPP仿真实验室10 分钟前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
devmoon13 分钟前
在 Polkadot 上部署独立区块链Paseo 测试网实战部署指南
开发语言·安全·区块链·polkadot·erc-20·测试网·独立链
lili-felicity14 分钟前
CANN流水线并行推理与资源调度优化
开发语言·人工智能
沐知全栈开发14 分钟前
CSS3 边框:全面解析与实战技巧
开发语言
lili-felicity17 分钟前
CANN模型量化详解:从FP32到INT8的精度与性能平衡
人工智能·python
数据知道20 分钟前
PostgreSQL实战:详解如何用Python优雅地从PG中存取处理JSON
python·postgresql·json
island131424 分钟前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络
曹牧29 分钟前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言