您好,登錄后才能下訂單哦!
Python中怎么獲取OneNet數據,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
使用python腳本文件對OneNet服務器數據進行上傳、獲取的操作
上傳數據
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2021/2/24 23:01 # @Author : LiShan # @Email : lishan_1997@126.com # @File : OneNet_Post.py # @Note : https://blog.csdn.net/lishan132/article/details/114044902 import urllib.request import json # 設備ID、Key deviceId = "591972034" APIKey = "ROsfgvwqy2jxn2x93TdDCCbFmL8=" # 上傳函數 def OneNet_post_data(info): url = "https://api.heclouds.com/devices/" + deviceId + '/datapoints' streams = [] for index, element in enumerate(info): streams.append({"id": element[0], "datapoints": [{"value": element[1]}]}) values = {"datastreams": streams} data = json.dumps(values).encode("utf-8") request = urllib.request.Request(url, data) request.add_header('api-key', APIKey) request.get_method = lambda: 'POST' request = urllib.request.urlopen(request) print(json.loads(request.read())) if __name__ == '__main__': upload_data = [ ["road1", 10], ["road2", 20], ["road3", 30], ["road4", 40], ["road5", 50], ["road6", 60], ["road7", 70], ["road8", 80], ["road9", 90], ["road10", 100], ["road11", 110], ["road12", 120], ] OneNet_post_data(upload_data)
獲取數據
#!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2021/2/24 23:01 # @Author : LiShan # @Email : lishan_1997@126.com # @File : OneNet_Get.py # @Note : https://blog.csdn.net/lishan132/article/details/114044902 import urllib.request import json # 設備ID、Key deviceId = "591972034" APIKey = "ROsfgvwqy2jxn2x93TdDCCbFmL8=" # 獲取函數 def OneNet_get_data(): url = "http://api.heclouds.com/devices/" + deviceId + "/datastreams" request = urllib.request.Request(url) request.add_header('api-key', APIKey) request.get_method = lambda: 'GET' request = urllib.request.urlopen(request) r = json.loads(request.read()) data = r.pop('data') print(r) return data if __name__ == '__main__': load_data = OneNet_get_data() print('參數' + '\t\t\t\t\t' + '更新時間' + '\t\t\t\t\t\t' + '數值') for index, element in enumerate(load_data): a = str(element.get('update_at', '')) b = str(element.get('current_value', '')) if a != "" and b != "": print(str(element['id']) + '\t\t\t\t' + a + '\t\t\t' + b)
整合為一個文件
#!/usr/bin/env python # -*- coding: utf-8 -*- # pip install prettytable import urllib.request as req import json # 設備ID、Key deviceId = "591972034" APIKey = "ROsfgvwqy2jxn2x93TdDCCbFmL8=" # 上傳函數 def OneNet_post_data(info): url = "https://api.heclouds.com/devices/" + info[0] + '/datapoints' headers = {'api-key': info[1]} streams = [] for i, e in enumerate(info[2]): streams.append({"id": e[0], "datapoints": [{"value": e[1]}]}) data = json.dumps({"datastreams": streams}).encode("utf-8") request = json.loads((req.urlopen(req.Request(url, data, headers=headers))).read()) print(request) # 獲取函數 def OneNet_get_data(info): url = "http://api.heclouds.com/devices/" + info[0] + "/datastreams" headers = {'api-key': info[1]} request = json.loads((req.urlopen(req.Request(url, headers=headers))).read()) data = request.pop('data') print(request) return data if __name__ == '__main__': # 準備待上傳數據 upload_data = [ ["road1", 10], ["road2", 20], ["road3", 30], ["road4", 40], ["road5", 50], ["road6", 60], ["road7", 70], ["road8", 80], ["road9", 90], ["road10", 100], ["road11", 110], ["road12", 120], ] # 上傳數據 OneNet_post_data([deviceId, APIKey, upload_data]) # 獲取數據 get_data = OneNet_get_data([deviceId, APIKey]) # noinspection PyBroadException try: # 使用表格美化顯示數據 import prettytable as pt tb = pt.PrettyTable() tb.field_names = ["id", "update_at", "current_value"] for index, element in enumerate(get_data): ID = str(element.get('id', '')) update_at = str(element.get('update_at', '')) current_value = str(element.get('current_value', '')) tb.add_row([ID, update_at, current_value]) print(tb) except Exception: # 直接顯示數據 for index, element in enumerate(get_data): ID = str(element.get('id', '')) update_at = str(element.get('update_at', '')) current_value = str(element.get('current_value', '')) print(ID, update_at, current_value)
看完上述內容,你們掌握Python中怎么獲取OneNet數據的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。