4、监测数据采集物联网应用开发步骤(4)

  1. 监测数据采集物联网应用开发步骤(3)

日志或文本文件读写开发

创建全局变量配置代码com.zxy.common.Com_Para.py全局变量根据需要后续补充。

#! python3
# -*- coding: utf-8 -
'''
Created on 2023年08月28日
@author: zxyong 13738196011
'''
#监测数据采集物联网应用--全局变量
import threading

#程序运行路径
ApplicationPath = ""
#操作系统识别 windows linux
devsys = "linux"
#编码格式
U_CODE = "UTF-8"
#文件夹路径根据windows操作系统或linux操作系统自动区分
zxyPath = "/"

新建日志或文本读写代码com.zxy.adminlog.UsAdmin_Log.py,日志文件命名格式参考“zxyong_20230824_1.log”其中日志文件大小超过1M自动新建日志文件。

#! python3
# -*- coding: utf-8 -
'''
Created on 2023年08月28日
@author: zxyong 13738196011
'''

import os
from com.zxy.common import Com_Para
from com.zxy.common.Com_Fun import Com_Fun

class UsAdmin_Log():    
    attContent = ''
    attFolder = ''
    attTFileName = ''
    attENCODE = ''
    
    def __init__(self,*args):
        self.attENCODE = Com_Para.U_CODE
        if len(args) == 2:
            self.attFolder = args[0] + Com_Para.zxyPath + "log"
            self.attContent = args[1]
        elif len(args) == 3:              
            self.attFolder = args[0] + '/log'
            self.attContent = args[1]
            self.attTFileName = args[2]
        elif len(args) == 4:
            self.attFolder =  args[0] + Com_Para.zxyPath + "data"
            self.attContent = args[1]
       
    def WriteData(self,inputDelay_code):
        self.HadForder()
        self.SaveFileData(inputDelay_code)

    # 编写默认log信息
    def WriteLog(self):
        self.HadForder()
        self.SaveFileDay()

    # 编写默认log信息
    def WriteExceptionLog(self,temClassName,temFunName):
        temIndexS = temClassName.rindex("\\")
        temIndexE = temClassName.rindex(".")
        temClass = temClassName[temIndexS+1:temIndexE]
        
        self.attContent = "==>"+temClass+"."+temFunName+"|\r"+self.attContent
        self.HadForder()
        self.SaveFileDay()
        
    # 编写日志,含内容
    def WriteLogAll(self, inputTContent):
        self.HadForder()
        self.SaveFileDayAll(inputTContent)
    
    # 编写带sub日志,含子文件夹
    def WriteLogSub(self, inputSubFile):
        self.HadForder()
        self.SaveFileDay(inputSubFile)       
            
    # 编写DEC日志
    def WriteLogSubDEC(self):
        self.WriteLogSub()
        self.WriteLogAll('DEC_SEC_')
    
    def InitWriteData(self,inputDelay_code):
        self.HadForder()
        self.InitSaveFileData(inputDelay_code)
    
    def InitSaveFileData(self,inputDelay_code):
        temStrTFileName = self.attFolder + Com_Para.zxyPath + inputDelay_code + ".dat"
        temFile = None
        try: 
            if os.path.exists(temStrTFileName) == False :
                temFile = open(temStrTFileName, 'w',encoding=self.attENCODE)
                temFile.write(self.attContent + "\r\n")
                temFile.close()
            else:
                pass
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
    
    def InitAppendFileData(self,inputDelay_code):
        temStrTFileName = self.attFolder + Com_Para.zxyPath + inputDelay_code + ".dat"
        temFile = None
        try: 
            if os.path.exists(temStrTFileName) == False :
                temFile = open(temStrTFileName, 'w',encoding=self.attENCODE)
                temFile.write(self.attContent + "\r\n")
                temFile.close()
            else:
                temFile = open(temStrTFileName, 'a',encoding=self.attENCODE)
                temFile.write(self.attContent + "\r\n")
                temFile.close()
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
                 
    # 判断文件夹是否存在,
    def HadForder(self):
        if os.path.exists(self.attFolder) == False:
            os.mkdir(self.attFolder)
    
    #读取文件内容
    def ReadFileToJson(self,inputFileName):
        temResult = []
        temFile = None
        try: 
            if os.path.exists(inputFileName) == False :
                temResult = []
            else:
                temFile = open(inputFileName, 'r',encoding=self.attENCODE)
                while True:
                    temLines = temFile.readline()
                    if len(temLines) > 0:
                        if temLines[0:1] != ",":
                            temResult.append(temLines)
                        else:
                            temResult.append(temLines[1:len(temLines)])
                    if not temLines:
                        break
                    pass
        except Exception as e:
            temResult = []
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
        return temResult
    
    #读取文件内容
    def ReadFile(self,inputFileName):
        temStrResult = ''
        temFile = None
        try: 
            if os.path.exists(inputFileName) == False :
                temStrResult = ""
            else:
                temFile = open(inputFileName, 'r',encoding=self.attENCODE)
                while True:
                    temLines = temFile.readline()
                    #整行读取数据
                    temStrResult += temLines
                    if not temLines:
                        break
                    pass
        except Exception as e:
            temStrResult = ""
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
        return temStrResult

    # 按日保存带内容日志文件
    def SaveFileDayAll(self, inputTContent):
        temStrLogName = ""
        if self.attTFileName == "":
            temStrLogName = self.attFolder + '/zxyong_' + Com_Fun.GetTime('%Y%m%d') + '_1.log'
        else:
            temStrLogName = self.attFolder + '/' + self.attTFileName + '.log'
        
        temFile = None
        try: 
            if os.path.exists(temStrLogName) == False :
                temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                temFile.write(inputTContent + "\r\n")
                temFile.close()
            else:
                temLgSize = os.path.getsize(temStrLogName)
                i = 2
                while 1 == 1:
                    if temLgSize > 1024 * 1024 :
                        if self.attTFileName == "":
                            temStrLogName = self.attFolder + "/zxyong_" + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"
                        else:
                            temStrLogName = self.attFolder + "/" + self.attTFileName + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"
                        
                        if os.path.exists(temStrLogName) == False :
                            temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                            temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                            temFile.write(inputTContent + "\r\n")
                            temFile.close()
                            break
                        else:
                            temLgSize = os.path.getsize(temStrLogName)
                    else:
                        temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                        temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                        temFile.write(inputTContent + "\r\n")
                        temFile.close()
                        break
                    i = i + 1
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
    
    # 按日保存带文件名日志文件,按日文件夹存储
    def SaveFileDaySub2(self, inputSub):
        temPath = self.attFolder +"/"+Com_Fun.GetTime("%Y-%m-%d")
        if os.path.exists(temPath) == False:
            os.mkdir(temPath)
        temStrLogName = temPath + '/zxyong_' + inputSub+"_" + Com_Fun.GetTime('%Y%m%d') + '_1.log'
        temFile = None
        try: 
            if os.path.exists(temStrLogName) == False :
                temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                temFile.write(self.attContent + "\r\n")
                temFile.close()
            else:
                temLgSize = os.path.getsize(temStrLogName)
                i = 2
                while 1 == 1:
                    if temLgSize > 1024 * 1024 :
                        temStrLogName = self.attFolder + '/zxyong_' + inputSub+"_" + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"           
                        if os.path.exists(temStrLogName) == False :
                            temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                            temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                            temFile.write(self.attContent + "\r\n")
                            temFile.close()
                            break
                        else:
                            temLgSize = os.path.getsize(temStrLogName)
                    else:
                        temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                        temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                        temFile.write(self.attContent + "\r\n")
                        temFile.close()
                        break
                    i = i + 1
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
                
    # 按日保存带文件名日志文件
    def SaveFileDaySub(self, inputSub):
        temStrLogName = self.attFolder + '/zxyong_' + inputSub+"_" + Com_Fun.GetTime('%Y%m%d') + '_1.log'
        
        temFile = None
        try: 
            if os.path.exists(temStrLogName) == False :
                temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                temFile.write(self.attContent + "\r\n")
                temFile.close()
            else:
                temLgSize = os.path.getsize(temStrLogName)
                i = 2
                while 1 == 1:
                    if temLgSize > 1024 * 1024 :
                        temStrLogName = self.attFolder + '/zxyong_' + inputSub+"_" + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"           
                        if os.path.exists(temStrLogName) == False :
                            temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                            temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                            temFile.write(self.attContent + "\r\n")
                            temFile.close()
                            break
                        else:
                            temLgSize = os.path.getsize(temStrLogName)
                    else:
                        temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                        temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r\n")
                        temFile.write(self.attContent + "\r\n")
                        temFile.close()
                        break
                    i = i + 1
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()
    
    # 按日保存日志文件
    def SaveFileDay(self):
        temStrLogName = ""
        if self.attTFileName == "":
            temStrLogName = self.attFolder + '/zxyong_' + Com_Fun.GetTime('%Y%m%d') + '_1.log'
        else:
            temStrLogName = self.attFolder + '/' + self.attTFileName+Com_Fun.GetTime('%Y%m%d') + '_1.log'
        
        temFile = None
        try: 
            if os.path.exists(temStrLogName) == False :
                temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r")
                temFile.write(self.attContent + "\r")
                temFile.close()
            else:
                temLgSize = os.path.getsize(temStrLogName)
                i = 2
                while 1 == 1:
                    if temLgSize > 1024 * 1024 :
                        if self.attTFileName == "":
                            temStrLogName = self.attFolder + "/zxyong_" + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"
                        else:
                            temStrLogName = self.attFolder + "/" + self.attTFileName + Com_Fun.GetTime('%Y%m%d') + "_" + str(i) + ".log"
                        
                        if os.path.exists(temStrLogName) == False :
                            temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                            temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r")
                            temFile.write(self.attContent + "\r")
                            temFile.close()
                            break
                        else:
                            temLgSize = os.path.getsize(temStrLogName)
                    else:
                        temFile = open(temStrLogName, 'a',encoding=self.attENCODE)
                        temFile.write("*********" + Com_Fun.GetTime('%Y-%m-%d %H:%M:%S') + "*********" + "\r")
                        temFile.write(self.attContent + "\r")
                        temFile.close()
                        break
                    i = i + 1
        except Exception as e:
            print(repr(e)+"=>"+str(e.__traceback__.tb_lineno))
        finally:
            if temFile != None:
                temFile.close()



日志调用代码MonitorDataCmd.py主文件中编写:

from com.zxy.adminlog.UsAdmin_Log import UsAdmin_Log

if __name__ == '__main__':下编写

        #全局变量参数设置
        Com_Para.ApplicationPath = os.path.abspath(os.path.dirname(__file__))
        if Com_Para.ApplicationPath[len(Com_Para.ApplicationPath) - 1 :len(Com_Para.ApplicationPath)] == "\\" or Com_Para.ApplicationPath[len(Com_Para.ApplicationPath) - 1 :len(Com_Para.ApplicationPath)] == "/":
            Com_Para.ApplicationPath = Com_Para.ApplicationPath[0 :len(Com_Para.ApplicationPath) - 1]
        sysstr = platform.system()
        if sysstr.lower() == "windows":
            Com_Para.devsys = "windows"
            Com_Para.zxyPath = "\\"
        elif sysstr.lower() == "linux":
            Com_Para.devsys = "linux"
            Com_Para.zxyPath = "/"

        temLog = "测试日志,默认日志"+Com_Fun.GetTimeDef()
        temInitLog = ""
        for i in range(1,20):
            temInitLog = temLog
            temLog = temLog +" " +Com_Fun.GetTimeDef()+";\r" + temInitLog
        uL = UsAdmin_Log(Com_Para.ApplicationPath, temLog)
        uL.WriteLog()
        print("默认日志文件成功,多次执行看看")
        
        temLog = "测试日志,含文件名日志"+Com_Fun.GetTimeDef()
        temInitLog = ""
        for i in range(1,20):
            temInitLog = temLog
            temLog = temLog +" " +Com_Fun.GetTimeDef()+";\r" + temInitLog
        uL = UsAdmin_Log(Com_Para.ApplicationPath, temLog)
        uL.SaveFileDaySub("exception")
        print("含文件名日志文件成功,多次执行看看")

日志文件效果如图:

4、监测数据采集物联网应用开发步骤(4)_第1张图片

  1. 监测数据采集物联网应用开发步骤(5.1)

你可能感兴趣的:(python,物联网)