修改完成

This commit is contained in:
caoqianming 2023-03-13 16:34:26 +08:00
parent a176f2a771
commit 3b9cc41a4b
7 changed files with 118 additions and 222 deletions

2
.gitignore vendored
View File

@ -1,5 +1,7 @@
*.exe
*.spec
*.zip
*.rar
venv/
dist/
build/

View File

@ -0,0 +1 @@
"样品各类","样品名",20.188,5.171,2.617,.243,61.438,5.132,3.471,1.011,.223,.109,.136,.019,.069,"11/12/2022 12:03:36 PM"

View File

@ -1,81 +0,0 @@
{
"SampleNo":"ID0001",
"TestDate":"2023-02-24 11:53",
"TestVaule":[
{
"标准名称":"0.41"
},
{
"loss":"0.67"
},
{
"SiO2":"0.34"
},
{
"Al2O3":"0.00"
},
{
"Fe2O3":"0.69"
},
{
"CaO":"0.24"
},
{
"MgO":"0.78"
},
{
"MnO":"0.58"
},
{
"SO3":"0.62"
},
{
"P2O5":"0.64"
},
{
"Cl-":"0.05"
},
{
"K2O":"0.45"
},
{
"Na2O":"0.81"
},
{
"R2O":"0.27"
},
{
"f-CaO":"0.61"
},
{
"KH":"0.91"
},
{
"KH-":"0.95"
},
{
"SM":"0.42"
},
{
"IM":"0.27"
},
{
"LSF":"0.36"
},
{
"C2S":"0.91"
},
{
"C3S":"0.04"
},
{
"C3A":"0.02"
},
{
"C4AF":"0.53"
},
{
"SUM":"0.92"
}
]
}

View File

@ -1,84 +0,0 @@
{
"SampleNo":"ID0002",
"TestDate":"2023-02-28 10:54",
"TestVaule":[
{
"检测项目":"0.62"
},
{
"loss":"0.57"
},
{
"SiO2":"0.37"
},
{
"Al2O3":"0.59"
},
{
"Fe2O3":"0.23"
},
{
"CaO":"0.41"
},
{
"MgO":"0.29"
},
{
"MnO":"0.78"
},
{
"TiO2":"0.16"
},
{
"SO3":"0.35"
},
{
"P2O5":"0.90"
},
{
"Cl-":"0.42"
},
{
"K2O":"0.88"
},
{
"Na2O":"0.06"
},
{
"R2O":"0.40"
},
{
"f-CaO":"null"
},
{
"KH":"null"
},
{
"KH-":"null"
},
{
"SM":"null"
},
{
"IM":"null"
},
{
"LSF":"null"
},
{
"C2S":"null"
},
{
"C3S":"null"
},
{
"C3A":"null"
},
{
"C4AF":"null"
},
{
"SUM":"null"
}
]
}

View File

@ -1,2 +1,4 @@
[ctc]
serverUrl=http://127.0.0.1:1234
format=TestPro,SampleNo,SiO2,Al2O3,Fe2O3,TiO2,CaO,MgO,SO3,K2O,Na2O,MnO,P2O5,Cr2O3,Cl-,TestDate
server=10.0.11.236
port=8080

View File

@ -4,74 +4,129 @@ import threading
from PIL import Image
from pystray import MenuItem
import time
import requests
# import requests
from datetime import datetime
import json
import shutil
from configparser import ConfigParser
import socket
import glob
class SnPost:
def __init__(self, server, port, format_str) -> None:
self.is_one_instance = False
self.is_working = False
self.icon = None # 下标
self.server = server
self.port = port
self.format_str = format_str
self.check_one_instance()
def close(icon, item):
global isWorking
isWorking = False
icon.stop()
def check_one_instance(self):
try:
global s
s = socket.socket()
host = socket.gethostname()
s.bind((host, 20309))
self.is_one_instance = True
except Exception:
self.is_one_instance = False
def close(self):
self.is_working = False
self.icon.stop()
def format_data(self, data):
format_list = format_str.split(',')
data = data.replace('"', '').replace('\r', '').replace('\n', '')
data_list = data.split(',')
post_data = {'TestVaule':[]}
ALL_ELEMENT = ["loss", "SiO2", "Al2O3", '"Fe2O3"', "CaO", "MgO", "MnO", "TiO2", "SO3", "P2O5", "Cl-", "K2O", "Na2O", "R2O", "f-CaO", "KH", "KH-", "SM", "IM", "LSF", "C2S", "C3S", "C3A", "C4AF", "SUM"]
HAS_ELEMENT = []
try:
for index, value in enumerate(format_list):
if value == 'SampleNo':
post_data['SampleNo'] = data_list[index]
elif value == 'TestDate':
dt = datetime.strptime(data_list[index], '%m/%d/%Y %I:%M:%S %p')
post_data['TestDate'] = dt.strftime('%Y-%m-%d %H:%M')
elif value == 'TestPro':
post_data['TestVaule'].append({'检测项目':data_list[index]})
else:
HAS_ELEMENT.append(value)
value_p = data_list[index]
if value_p.startswith('.'):
value_p = '0' + value_p
post_data['TestVaule'].append({value:value_p})
difference = set(ALL_ELEMENT).difference(set(HAS_ELEMENT))
for i in difference:
post_data['TestVaule'].append({i:None})
return json.dumps(post_data, ensure_ascii=False)
except:
import traceback
print(traceback.format_exc())
self.icon.notify(message='数据格式解析失败', title="ctc数据推送")
return None
def check_one_instance():
try:
global s
s = socket.socket()
host = socket.gethostname()
s.bind((host, 20309))
return True
except Exception:
print('already has an instance')
return False
def run(self):
if not self.is_one_instance:
return
menu = (MenuItem('退出', self.close), )
image = Image.open("favicon.ico")
title = "ctc数据推送"
self.icon = pystray.Icon(title, image, "ctc数据推送", menu)
threading.Thread(target=self.icon.run, daemon=True).start()
def main():
conf = ConfigParser() # 需要实例化一个ConfigParser对象
conf.read('conf.ini')
global isWorking
isWorking = True
serverUrl = conf['ctc']['serverUrl']
currentPath = os.getcwd()
backupPath = os.path.join(currentPath, 'backup')
if not os.path.exists(backupPath):
os.mkdir(backupPath)
menu = (MenuItem('退出', close), )
image = Image.open("favicon.ico")
title = "ctc数据推送"
icon = pystray.Icon(title, image, "ctc数据推送", menu)
threading.Thread(target=icon.run, daemon=True).start()
while isWorking:
files = os.listdir(currentPath)
for file in files:
file_path = os.path.join(currentPath, file)
if file_path.endswith('.txt'):
with open(file_path, 'r', encoding="utf-8") as f:
post_data = json.load(f)
for i in post_data['TestVaule']:
for k in i:
if i[k] == 'null':
i[k] = None
try:
requests.post(url=serverUrl, json=post_data)
server_addr = (server, int(port))
self.is_working = True
filename_pattern = "*.dat"
# 获取当前工作目录
current_dir = os.getcwd()
while self.is_working:
files = glob.glob(os.path.join(current_dir, filename_pattern))
print(files)
for file in files:
# file_path = os.path.join(currentPath, file)
# if file_path.endswith('.txt'):
# with open(file_path, 'r', encoding="utf-8") as f:
# post_data = json.load(f)
# for i in post_data['TestVaule']:
# for k in i:
# if i[k] == 'null':
# i[k] = None
with open(file, 'r') as f:
post_data = self.format_data(f.read())
if post_data:
try:
shutil.move(file_path, backupPath)
except Exception:
os.remove(file_path)
except Exception as e:
err = '服务器错误:{}'.format(e.__str__()[0:80])
icon.notify(message=err)
time.sleep(3)
# requests.post(url=serverUrl, json=post_data)
tcp_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcp_socket.settimeout(3)
tcp_socket.connect(server_addr)
tcp_socket.sendall(post_data.encode('utf-8'))
os.rename(file, file+'_bak')
except Exception as e:
err = '服务器错误:{}'.format(e.__str__()[0:80])
self.icon.notify(message=err, title="ctc数据推送")
finally:
tcp_socket.close()
else:
return
time.sleep(3)
if __name__ == '__main__':
if check_one_instance():
main()
conf = ConfigParser() # 需要实例化一个ConfigParser对象
conf.read('conf.ini')
# serverUrl = conf['ctc']['serverUrl']
server = conf['ctc']['server']
port = conf['ctc']['port']
format_str = conf['ctc']['format']
snpost = SnPost(server, port, format_str)
snpost.run()
# 打包命令
# pyinstaller -F -w -i favicon.ico ctc数据推送.py

1
requirements.txt Normal file
View File

@ -0,0 +1 @@
pystray==0.19.4