Explorar el Código

获取博锐数据

李莎 hace 1 año
commit
ba3e0ceb35

+ 9 - 0
Dockerfile

@@ -0,0 +1,9 @@
+FROM python:3.7.15-slim
+
+
+WORKDIR ./saga_transfer_energy
+ADD . .
+
+RUN pip install --upgrade pip && pip install --no-cache-dir --upgrade -r requirements.txt
+
+CMD ["python", "-u","./main.py"]

+ 49 - 0
MyUtils/ConfigUtils.py

@@ -0,0 +1,49 @@
+import xml.etree.ElementTree as ET
+
+
+#读取xml文件
+class ConfigUtils():
+    def __init__(self,file):
+        self.url = ""
+        self.tree = ET.parse(file)
+        self.root = self.tree.getroot()
+
+    def readTop(self, key, child):
+        datas = []
+        data = self.root.find(key)
+        for key in child:
+            datas.append(data.get(key))
+        return datas
+
+    def readTopDict(self, key, child):
+        datas = {}
+        data = self.root.find(key)
+        for key in child:
+            datas[key] = data.get(key)
+        return datas
+
+    def readConfig(self,parent,child):
+        datas=[]
+        for childLine in self.root.find(parent):
+            data=[]
+            for key in child:
+                data.append(childLine.get(key))
+            datas.append(data)
+        return datas
+
+    def readConfigDict(self,parent,child):
+        datas=[]
+        for childLine in self.root.find(parent):
+            data={}
+            for key in child:
+                data[key]=childLine.get(key)
+            datas.append(data)
+        return datas
+
+    def readConfigSingle(self,key):
+        data = self.root.find(key).text
+        return data
+
+
+if __name__ == '__main__':
+    config = ConfigUtils("logger.conf")

+ 137 - 0
MyUtils/DateUtils.py

@@ -0,0 +1,137 @@
+import datetime
+from dateutil.relativedelta import relativedelta
+from dateutil import rrule
+
+YYmmddHHMMSS = "%Y%m%d%H%M%S"
+YYmmdd = "%Y%m%d"
+YYmm = "%Y%m"
+# 根据开始月份结束月份获取所有月份
+def get_each_month(start_month, end_month):
+    if str(start_month).count('-') != 1 or str(end_month).count('-') != 1:
+        print("Parameter Error: Pls input a string such as '2019-01'")
+        return []
+    if int(str(start_month).split('-')[1]) > 12 or int(str(end_month).split('-')[1]) > 12:
+        print('Parameter Error: Pls input correct month range such as between 1 to 12')
+        return []
+    if int(str(start_month).split('-')[1]) == 0 or int(str(end_month).split('-')[1]) == 13:
+        print('Parameter Error: Pls input correct month range such as between 1 to 12')
+        return []
+    start = datetime.datetime.strptime(start_month, "%Y-%m")
+    end = datetime.datetime.strptime(end_month, "%Y-%m")
+    month_count = rrule.rrule(rrule.MONTHLY, dtstart=start, until=end).count()  # 计算总月份数
+    if end < start:
+        print("Parameter Error: Pls input right date range,start_month can't latter than end_month")
+        return []
+    else:
+        list_month = []
+        year = int(str(start)[:7].split('-')[0])  # 截取起始年份
+        for m in range(month_count):  # 利用range函数填充结果列表
+            month = int(str(start)[:7].split('-')[1])  # 截取起始月份,写在for循环里,作为每次迭代的累加基数
+            month = month + m
+            if month > 12:
+                if month % 12 > 0:
+                    month = month % 12  # 计算结果大于12,取余数
+                    if month == 1:
+                        year += 1  # 只需在1月份的时候对年份加1,注意year的初始化在for循环外
+                else:
+                    month = 12
+            if len(str(month)) == 1:
+                list_month.append(str(year) + '-0' + str(month))
+            else:
+                list_month.append(str(year) + '-' + str(month))
+        return list_month
+
+
+# 转换格式,去掉"-",%Y%m
+def get_eachmonth(start_month, end_month):
+    startmonth = start_month[0:4] + "-" + start_month[4:6]
+    endmonth = end_month[0:4] + "-" + end_month[4:6]
+    months = get_each_month(startmonth, endmonth)
+    list_month = [i[0:4] + i[5:7] for i in months]
+    return list_month
+
+
+def get_month(starttime, endtime):
+    months = []
+    starttime = datetime.datetime.strptime(starttime, YYmmddHHMMSS)
+    endtime = datetime.datetime.strptime(endtime, YYmmddHHMMSS)
+    while starttime <= endtime:
+        start = starttime.strftime("%Y%m")
+        if start not in months:
+            months.append(start)
+        starttime = starttime + datetime.timedelta(days=1)
+    return months
+
+def get_month_range(starttime, endtime):
+    months = []
+    starttime = datetime.datetime.strptime(starttime[0:8], YYmmdd)
+    endtime = datetime.datetime.strptime(endtime[0:8], YYmmdd)
+    while starttime <= endtime:
+        start = starttime.strftime(YYmmddHHMMSS)
+        endMonth = datetime.datetime.strptime(start[0:6], YYmm) + relativedelta(months=+1)
+
+        end = endMonth.strftime(YYmmddHHMMSS)
+        if endtime <= endMonth:
+            end = endtime.strftime(YYmmddHHMMSS)
+        starttime = endMonth
+        months.append([start, end])
+    return months
+
+
+
+def get_month1(starttime, endtime):
+    months = []
+    startyear = int(starttime[0:4])
+    startmonth = int(starttime[4:6])
+    endyear = int(endtime[0:4])
+    endmonth = int(endtime[4:6])
+    while startyear != endyear or startmonth != endmonth:
+        startyearstr = str(startyear)
+        startmonthstr = str(startmonth)
+        if startmonth < 10:
+            startmonthstr = "0" + str(startmonth)
+        months.append(startyearstr + startmonthstr)
+        startmonth += 1
+        if startmonth == 13:
+            startyear += 1
+            startmonth = 1
+    months.append(endtime[0:6])
+    return months
+
+#根据开始结束时间获取最大区间为1天的时间区间
+# def get_day(starttime,endtime):
+#     times = []
+#     starttime = datetime.datetime.strptime(starttime, YYmmddHHMMSS)
+#     endtime = datetime.datetime.strptime(endtime, YYmmddHHMMSS)
+#     while starttime < endtime:
+#         start = starttime.strftime(YYmmddHHMMSS)
+#         starttime_delta = starttime + datetime.timedelta(days=1)
+#         end = starttime_delta.strftime(YYmmddHHMMSS)
+#         if str(starttime)[0:7]<str(starttime_delta)[0:7] :
+#             end = starttime_delta.strftime("%Y%m") +"01000000"
+#             starttime = datetime.datetime.strptime(end, YYmmddHHMMSS)
+#             times.append([start, end])
+#             continue
+#         if starttime >= starttime_delta:
+#             end = starttime_delta.strftime(YYmmddHHMMSS)
+#         starttime = starttime + datetime.timedelta(days=1)
+#         times.append([start,end])
+#     return times
+#根据开始结束时间获取最大区间为1天的时间区间
+def get_day(starttime,endtime):
+    times = []
+    starttime = datetime.datetime.strptime(starttime, YYmmddHHMMSS)
+    endtime = datetime.datetime.strptime(endtime, YYmmddHHMMSS)
+    while starttime < endtime:
+        start = starttime.strftime(YYmmddHHMMSS)
+        stratDay = datetime.datetime.strptime(start[0:8],YYmmdd)
+        starttime_delta = stratDay + datetime.timedelta(days=1)
+        end = starttime_delta.strftime(YYmmddHHMMSS)
+        if endtime <= starttime_delta:
+            end = endtime.strftime(YYmmddHHMMSS)
+        starttime = stratDay + datetime.timedelta(days=1)
+        times.append([start,end])
+    return times
+
+if __name__ == '__main__':
+    print(get_month_range("20200106000000", "20200115000000"))

+ 7 - 0
MyUtils/Dingtalk.py

@@ -0,0 +1,7 @@
+from  dingtalkchatbot.chatbot import DingtalkChatbot
+
+def send_message(message,dingtalk,mobiles):
+    webhook = dingtalk
+    xiaoding = DingtalkChatbot(webhook)
+    xiaoding.send_text(msg=message,at_mobiles=[mobiles],is_auto_at=False)
+    return

+ 67 - 0
MyUtils/DmprwdUtil.py

@@ -0,0 +1,67 @@
+from MyUtils.HttpRequestsUtil import *
+
+url = "https://doimp.persagy.com/"
+energyId_path = "energy-research/common/api/energy/model/project/list"
+rwdId_path = "energy-research/common/api/multi/energy/model/item/list"
+query_data = "dmp-rwd/rwd/ipcal/data/queryIPDataInPeriod?groupCode=YS&projectId=Pj1101080259"
+
+
+#1.获取项目属于哪个集团,这里博锐属于散楼,groupCode=YS
+#2.获取项目能耗模型id,根据以上energyId_path获取id,id=1000001
+#3.获取分项树形结构,根据rwdId_path路径和能耗分项item获取rwdId,
+# {itemName:博锐尚格总电耗,itemCode:EI1001,rwdId:Vo1101080259f2481ca3604644399f1dacb84e20adae},
+# {itemName:照明与插座,itemCode:EI1010202001,rwdId:Vo110108025953894df8d4ae4dbeb7c81ced7df3f83e},
+# {itemName:空调末端,itemCode:EI10102010102001,rwdId:Vo11010802590eaef68d3289452d86d89fbee721e6df},
+# {itemName:冷热源,itemCode:EI10102010101001,rwdId:Vo1101080259e6dcf338d9be4bbf826f659b0b5a9ab2},
+#4.获取数据,根据以上query_data路径和rwdId获取数据
+
+data_url = url + query_data
+def get_query_data(startTime,endTime):
+    payload = {
+    "objects": [
+        {
+            "objectId": "Vo1101080259f2481ca3604644399f1dacb84e20adae",
+            "infoCodes": [
+                "subentryAccConsum"
+            ]
+        },
+        {
+            "objectId": "Vo110108025953894df8d4ae4dbeb7c81ced7df3f83e",
+            "infoCodes": [
+                "subentryAccConsum"
+            ]
+        },
+        {
+            "objectId": "Vo11010802590eaef68d3289452d86d89fbee721e6df",
+            "infoCodes": [
+                "subentryAccConsum"
+            ]
+        },
+        {
+            "objectId": "Vo1101080259e6dcf338d9be4bbf826f659b0b5a9ab2",
+            "infoCodes": [
+                "subentryAccConsum"
+            ]
+        }
+    ],
+    "ipType": "1d",
+    "startTime": startTime,
+    "endTime": endTime,
+    "dataStatus": 1
+}
+    headers = {
+        'Content-Type': 'application/json'
+    }
+    res = HttpRequestsUtil.post(data_url,payload,headers)
+    data = res["data"]
+    return data
+
+
+
+
+
+
+
+if __name__ == '__main__':
+    data = get_query_data("20230701000000","20230702000000")
+    print(data)

+ 23 - 0
MyUtils/HttpRequestsUtil.py

@@ -0,0 +1,23 @@
+# coding=utf-8
+import requests
+import json
+
+
+
+class HttpRequestsUtil(object):
+    #post方法获取数据  application/json
+    @staticmethod
+    def post(url, postData,headers):  #
+        data = json.dumps(postData)
+        response = requests.request("POST",url, data=data.encode('utf-8'),
+                              headers=headers)
+        res = response.json()
+        return res
+
+
+
+
+# if __name__ == '__main__':
+    # httputil = HttpRequestsUtil()
+    # httputil.postText()
+    # HttpUtil.postText()

+ 44 - 0
MyUtils/HttpUtil.py

@@ -0,0 +1,44 @@
+# coding=utf-8
+import sys
+
+if (sys.version_info.major == 3):
+    from urllib import parse
+    import urllib.request as urllib2
+else:
+    import urllib2
+
+
+class HttpUtil(object):
+    #post方法获取数据  application/json
+    @staticmethod
+    def post(url, postData):  #
+        req = urllib2.Request(url, data=postData.encode('utf-8'),
+                              headers={'Content-Type': 'application/json;charset=UTF-8'})
+        res = urllib2.urlopen(req, timeout=60).read().decode("utf-8")
+        return res
+
+
+
+    #post方法获取数据  application/x-www-form-urlencoded
+    @staticmethod
+    def postText(url, postData):
+        req = urllib2.Request(url, data=postData.encode('utf-8'),
+                              headers={'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'})
+        res = urllib2.urlopen(req, timeout=60).read().decode("utf-8")
+        return res
+
+    #get方法获取数据  text/xml
+    @staticmethod
+    def get(url, getData, isquote):
+        if isquote:
+            getData = parse.quote(getData)
+        req = urllib2.Request((url + getData), headers={'Content-Type': 'text/xml;charset=UTF-8'})
+        res = urllib2.urlopen(req, timeout=60)
+        req = res.read()
+        return req.decode()
+
+
+# if __name__ == '__main__':
+    # httputil = HttpUtil()
+    # httputil.postText()
+    # HttpUtil.postText()

+ 53 - 0
MyUtils/MetadataWebUtil.py

@@ -0,0 +1,53 @@
+import json
+from MyUtils.HttpUtil import *
+
+
+class MetadataWebUtil(object):
+    def __init__(self, url):
+        self.url = url
+
+    def get_hbase(self, params):
+        params = json.dumps(params)
+        word = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ser="http://service.persagy.com/" xmlns:ent="http://entity.persagy.com">' \
+               '<soapenv:Header/>' \
+               '<soapenv:Body><ser:Query>' \
+               '<arg0>%s</arg0>' \
+               '</ser:Query></soapenv:Body></soapenv:Envelope>' % (params)
+        res = HttpUtil.post(self.url, word)
+        res = res.split("<return>")[1].split("</return>")[0]
+        res = json.loads(res.replace("&#xd;", ""))
+        return res
+
+    def database_list(self):
+        params = {
+            "QueryType": "database_list"
+        }
+        res = self.get_hbase(params)
+        return res["Content"]
+
+    def table_list(self, database):
+        params = {
+            "QueryType": "table_list_strict",
+            "Database": database
+        }
+        table_list_strict = self.get_hbase(params)["Content"]
+        params = {
+            "QueryType": "table_list",
+            "Database": database
+        }
+        table_list = self.get_hbase(params)["Content"]
+        table_list = [i for i in table_list if i not in table_list_strict]
+        tables = {}
+        for table in table_list_strict:
+            childs = []
+            for i in table_list:
+                if i.startswith(table + "_"):
+                    try:
+                        word = i[len(table + "_"):]
+                        if len(word) == 4 or len(word) == 6:
+                            word = int(word)
+                            childs.append(i)
+                    except:
+                        pass
+            tables[table] = childs
+        return tables

+ 72 - 0
MyUtils/MysqlUtils.py

@@ -0,0 +1,72 @@
+import pymysql
+from dbutils.pooled_db import PooledDB
+
+
+class MysqlUtils():
+    # 连接池对象
+    __pool = None
+    def __init__(self,**config):
+        self.host = config["host"]
+        self.port = int(config["port"])
+        self.user = config["user"]
+        self.passwd = config["passwd"]
+        self.database = None
+        if "database" in config:
+            self.database = config["database"]
+        self.pool = self.get_conn()
+        # self.pool = None
+
+    def get_conn(self):
+        if MysqlUtils.__pool is None:
+            __pool = PooledDB(pymysql, mincached=1, maxcached=5, maxconnections=5,
+                              host=self.host, port=self.port, user=self.user, passwd=self.passwd,
+                              database=self.database,
+                               use_unicode=False, blocking=False, charset="utf8")
+            self.pool = __pool
+            return __pool
+
+
+    def query(self,sql):
+        con = None
+        cur = None
+        try:
+            con = self.pool.connection()
+            cur = con.cursor()
+            count = cur.execute(sql)
+            if count > 0:
+                result = cur.fetchall()
+                result = [[j.decode() if isinstance(j,bytes) else j for j in i] for i in result]
+                print(result)
+            else:
+                result = False
+            return result
+        except Exception as e:
+            print(e)
+        finally:
+            if cur:
+                cur.close()
+            if con:
+                con.close()
+
+
+    def update(self,sql):
+        con = None
+        cur = None
+        try:
+            con = self.pool.connection()
+            cur = con.cursor()
+            cur.execute(sql)
+            con.commit()
+        except Exception as e:
+            con.rollback()  # 事务回滚
+            print(e)
+        finally:
+            if cur:
+                cur.close()
+            if con:
+                con.close()
+
+    def close(self):
+        if MysqlUtils.__pool:
+            MysqlUtils.__pool.close()
+

+ 104 - 0
MyUtils/ZillionUtil.py

@@ -0,0 +1,104 @@
+from MyUtils.MetadataWebUtil import MetadataWebUtil
+
+
+class ZillionUtil():
+    def __init__(self, url):
+        self.metadata = MetadataWebUtil(url)
+
+    ##列出所有数据库
+    def database_list(self):
+        param = {
+            "QueryType": "database_list"
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Content"]
+
+        # TODO  其他zillion语句
+
+    ##列出所有数据库下的表(不包含分表)
+    def table_list_strict(self,table):
+        param = {
+            	"QueryType":"table_list_strict",
+	            "Database":table
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Content"]
+
+
+    ##列出所有数据库
+    # def query(self, database, table, Criteria):
+    #     param = {
+    #         "QueryType": "select",
+    #         "Database": database,
+    #         "Datatable": table,
+    #         "Criteria": Criteria
+    #     }
+    #     print(param)
+    #     databases = self.metadata.get_hbase(param)
+    #     return databases["Content"]
+
+    def select(self, database, table, Criteria):
+        param = {
+            "QueryType": "select",
+            "Database": database,
+            "Datatable": table,
+            "Criteria": Criteria
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Content"]
+
+    def table_key(self, database, table):
+        param = {
+            "QueryType": "table_detail",
+            "Database": database,
+            "Datatable": table
+        }
+        databases = self.metadata.get_hbase(param)
+        key = databases["Content"]["Key"]
+        return key
+
+
+
+    def select_count(self, database, table, Criteria):
+        param = {
+            "QueryType": "select_count",
+            "Database": database,
+            "Datatable": table,
+            "Criteria": Criteria
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Count"]
+
+    def query_data(self, sql):
+        databases = self.metadata.get_hbase(sql)
+        return databases["Content"]
+
+    def insert(self,database,table,InsertObject):
+        param = {
+            "QueryType": "batch_insert",
+            "Database": database,
+            "Datatable": table,
+            "InsertObjects": InsertObject
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Count"]
+
+    def remove(self,database,table,key):
+        param = {
+            "QueryType": "remove",
+            "Database": database,
+            "Datatable": table,
+            "Key": key
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Count"]
+
+    def put(self,database,table,InsertObject):
+        param = {
+            "QueryType": "batch_put",
+            "Database": database,
+            "Datatable": table,
+            "InsertObjects": InsertObject
+        }
+        databases = self.metadata.get_hbase(param)
+        return databases["Result"]

+ 11 - 0
config.json

@@ -0,0 +1,11 @@
+{
+  "mysql": {
+    "host": "rm-2zek656j2bn934176xo.mysql.rds.aliyuncs.com",
+    "port": 53306,
+    "user": "root",
+    "passwd": "H%k3!BHw1kQXIc70",
+    "database": "sagacloud_review"
+  },
+  "dingding": "https://oapi.dingtalk.com/robot/send?access_token=51a1f6f067341fc1647479cff0349c2f94d0165f760bf973b24336bfdc349d34",
+  "at_mobiles": "15727360513"
+}

+ 91 - 0
main.py

@@ -0,0 +1,91 @@
+import datetime
+import json,pymysql
+import os
+import time
+from MyUtils.MysqlUtils import MysqlUtils
+from MyUtils.Dingtalk import send_message
+from MyUtils.DmprwdUtil import get_query_data
+import pytz
+
+INSERT_SQL = "replace into %s.%s(project_id,date,energy_cooling,energy_heating,energy_ac_terminal,energy_light,energy_others,create_time,update_time) values "
+DELETE_SQL = "DELETE FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s' "
+SELETE_COUNTLASTDATA_SQL = "SELECT count(*) FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s'"
+SELETE_SUMLASTDATA_SQL = "SELECT SUM(energy_ac_terminal)+SUM(energy_heating)+SUM(energy_cooling)+SUM(energy_light)+sum(energy_others) as last_data FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s'"
+
+with open("config.json", "r") as f:
+    data = json.load(f)
+    mysql = data["mysql"]
+    my_database = mysql["database"]
+    dingding = data["dingding"]
+    at_mobiles = data["at_mobiles"]
+
+def datetime_now():
+    # datetime_now = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
+    #容器时间
+    # tz = pytz.timezone('Asia/Shanghai')  # 东八区
+    datetime_now = datetime.datetime.fromtimestamp(int(time.time()),
+                                    pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S')
+    return datetime_now
+
+
+building = "1101080259"
+def transfer_energy():
+    print("同步%s项目数据" % (building))
+    while True:
+        project_id = "Pj" + building
+        time_now = datetime.datetime.fromtimestamp(int(time.time()),
+                                                   pytz.timezone('Asia/Shanghai')).strftime('%H:%M:%S')
+        am_set_time = "08:00:00"
+        pm_set_time = "22:00:00"
+        if time_now == am_set_time or time_now ==pm_set_time:#此处设置每天定时的时间
+            today = datetime.date.today().strftime("%Y%m%d")+"000000"
+            yesterday = (datetime.date.today() - datetime.timedelta(days=1)).strftime("%Y%m%d")+"000000"
+            today_date = datetime.date.today().strftime("%Y%m%d")
+            yesterday_date = (datetime.date.today() - datetime.timedelta(days=1)).strftime("%Y%m%d")
+
+
+            # #连接mysql
+            MysqlUtil = MysqlUtils(**mysql)
+            #获取能耗数据
+            datas = get_query_data(yesterday,today)
+            if datas:
+                # 删除昨天数据
+                print("%s,开始删除%s的数据..." % (datetime_now(), yesterday))
+                delete_sql = DELETE_SQL % (project_id, yesterday_date, today_date)
+                MysqlUtil.update(delete_sql)
+                objectids = [i["objectId"] for i in datas]
+                print(objectids)
+                energy_cooling = "0"
+                energy_heating = "0"
+                energy_ac_terminal = "0"
+                energy_light = "0"
+                sum_data_value = "0"
+                for i in datas:
+                    print(i)
+                    #总电耗
+                    if i["objectId"] == "Vo1101080259f2481ca3604644399f1dacb84e20adae":
+                        sum_data_value = i["ipValue"]
+                    #冷热源
+                    if i["objectId"] == "Vo1101080259e6dcf338d9be4bbf826f659b0b5a9ab2":
+                        energy_cooling = i["ipValue"]
+                    #空调末端
+                    if i["objectId"] == "Vo11010802590eaef68d3289452d86d89fbee721e6df":
+                        energy_ac_terminal = i["ipValue"]
+                    #照明
+                    if i["objectId"] == "Vo110108025953894df8d4ae4dbeb7c81ced7df3f83e":
+                        energy_light = i["ipValue"]
+
+                energy_other = float(sum_data_value) - float(energy_cooling) - float(energy_heating)- float(energy_light) - float(energy_ac_terminal)
+                sql = "('%s','%s','%s','%s','%s','%s','%s','%s','%s')" % (
+                    project_id, yesterday_date, energy_cooling, energy_heating, energy_ac_terminal, energy_light, energy_other,
+                    datetime_now(), datetime_now())
+                inser_sql = INSERT_SQL % (my_database, "energy_week_day") + sql
+                print("%s,开始插入数据..." % datetime_now())
+                MysqlUtil.update(inser_sql)
+            else:
+                print("%s,没有查询到数据...")
+
+            MysqlUtil.close()
+
+if __name__ == '__main__':
+    transfer_energy()

+ 5 - 0
requirements.txt

@@ -0,0 +1,5 @@
+requests==2.27.1
+pymysql==1.0.2
+dbutils==2.0.2
+pytz==2021.1
+dingtalkchatbot==1.5.2

+ 96 - 0
temp.py

@@ -0,0 +1,96 @@
+import datetime
+import json,pymysql
+import os
+import time
+from MyUtils.MysqlUtils import MysqlUtils
+from MyUtils.Dingtalk import send_message
+from MyUtils.DmprwdUtil import get_query_data
+from MyUtils.DateUtils import get_day
+import pytz
+
+INSERT_SQL = "replace into %s.%s(project_id,date,energy_cooling,energy_heating,energy_ac_terminal,energy_light,energy_others,create_time,update_time) values "
+DELETE_SQL = "DELETE FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s' "
+SELETE_COUNTLASTDATA_SQL = "SELECT count(*) FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s'"
+SELETE_SUMLASTDATA_SQL = "SELECT SUM(energy_ac_terminal)+SUM(energy_heating)+SUM(energy_cooling)+SUM(energy_light)+sum(energy_others) as last_data FROM `energy_week_day` WHERE `project_id` = '%s' AND `date` >= '%s' AND `date` < '%s'"
+
+with open("config.json", "r") as f:
+    data = json.load(f)
+    mysql = data["mysql"]
+    my_database = mysql["database"]
+    dingding = data["dingding"]
+    at_mobiles = data["at_mobiles"]
+
+def datetime_now():
+    # datetime_now = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
+    #容器时间
+    # tz = pytz.timezone('Asia/Shanghai')  # 东八区
+    datetime_now = datetime.datetime.fromtimestamp(int(time.time()),
+                                    pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S')
+    return datetime_now
+
+
+# #连接hbase
+MysqlUtil = MysqlUtils(**mysql)
+
+building = "1101080259"
+
+start_time = "20230712000000"
+end_time = "20230719000000"
+range_days = get_day(start_time,end_time)
+
+for i in range_days:
+    yesterday,today = i[0],i[1]
+    yesterday_date = yesterday[0:8]
+    today_date = today[0:8]
+    print("同步%s项目数据"%(building))
+    project_id = "Pj" + building
+    time_now = datetime.datetime.fromtimestamp(int(time.time()),
+                                               pytz.timezone('Asia/Shanghai')).strftime('%H:%M:%S')
+    # today = datetime.date.today().strftime("%Y%m%d")+"000000"
+    # yesterday = (datetime.date.today() - datetime.timedelta(days=1)).strftime("%Y%m%d")+"000000"
+    # today_date = datetime.date.today().strftime("%Y%m%d")
+    # yesterday_date = (datetime.date.today() - datetime.timedelta(days=1)).strftime("%Y%m%d")
+    #
+
+    print(today,yesterday)
+
+    #获取能耗数据
+    datas = get_query_data(yesterday,today)
+    if datas:
+        # 删除昨天数据
+        print("%s,开始删除%s的数据..." % (datetime_now(), yesterday))
+        delete_sql = DELETE_SQL % (project_id, yesterday_date, today_date)
+        MysqlUtil.update(delete_sql)
+        objectids = [i["objectId"] for i in datas]
+        energy_cooling = "0"
+        energy_heating = "0"
+        energy_ac_terminal = "0"
+        energy_light = "0"
+        sum_data_value = "0"
+        for i in datas:
+            #总电耗
+            if i["objectId"] == "Vo1101080259f2481ca3604644399f1dacb84e20adae":
+                sum_data_value = i["ipValue"]
+            #冷热源
+            if i["objectId"] == "Vo1101080259e6dcf338d9be4bbf826f659b0b5a9ab2":
+                energy_cooling = i["ipValue"]
+            #空调末端
+            if i["objectId"] == "Vo11010802590eaef68d3289452d86d89fbee721e6df":
+                energy_ac_terminal = i["ipValue"]
+            #照明
+            if i["objectId"] == "Vo110108025953894df8d4ae4dbeb7c81ced7df3f83e":
+                energy_light = i["ipValue"]
+
+        print(sum_data_value,energy_cooling,energy_ac_terminal,energy_light)
+        energy_other = float(sum_data_value) - float(energy_cooling) - float(energy_heating)- float(energy_light) - float(energy_ac_terminal)
+        sql = "('%s','%s','%s','%s','%s','%s','%s','%s','%s')" % (
+            project_id, yesterday_date, energy_cooling, energy_heating, energy_ac_terminal, energy_light, energy_other,
+            datetime_now(), datetime_now())
+        inser_sql = INSERT_SQL % (my_database, "energy_week_day") + sql
+        print("%s,开始插入数据..." % datetime_now())
+        MysqlUtil.update(inser_sql)
+    else:
+        print("%s,没有查询到数据...")
+
+MysqlUtil.close()
+