-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAddPatient.py
120 lines (95 loc) · 3.77 KB
/
AddPatient.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
# 使用UTF-8标准编码避免中文乱码
# -*- coding: UTF-8 -*-
#Qt相关
from PyQt5.QtWidgets import QDialog, QMessageBox
from PyQt5.QtCore import pyqtSlot, pyqtSignal,Qt
#加载UI
from UI.Ui_AddPatient import Ui_Dialog
#导入配置文件
from Util.Common import get_sql_connection, get_logger, show_error_message, show_successful_message
import datetime
# 添加新样品类
class AddPatient(QDialog):
#发出信号(类型是list)
#todo:
#其实不大明白这个信号的意义
data_update_signal = pyqtSignal(list)
#把当前位置location串进来了
def __init__(self, parent=None,location=None):
super(AddPatient, self).__init__(parent)
#ui初始化
self.__UI = Ui_Dialog()
self.__UI.setupUi(self)
#初始化sql相关
self.connection = None
self.cursor = None
self.logger = None
self.set_connection_cursor()
self.set_logger()
self.location = location
# 单击【提交】按钮槽函数
@pyqtSlot()
def on_btn_commit_clicked(self):
sql_find,sql,data_list = self.get_insert_sql_data()
try:
self.cursor.execute(sql_find)
num = self.cursor.fetchone()[0]
if num > 0:
show_error_message(self, "已存在该编号的病人!")
else:
self.cursor.execute(sql)
self.connection.commit()
show_successful_message(self, "插入成功")
self.data_update_signal.emit(data_list)
except Exception as e:
show_error_message(self, "插入错误,请检查!")
self.record_debug(e)
self.close()
# 设置cursor和connection
def set_connection_cursor(self) -> None:
self.connection = get_sql_connection()
self.cursor = self.connection.cursor()
# 设置日志处理器
def set_logger(self) -> None:
self.logger = get_logger("my_logger")
def get_insert_sql_data(self) -> (str, list):
sql = None
#列表
data_list = []
#病人编号
pID = self.__UI.lineEdit_pID.text()
#病人姓名
pname = self.__UI.lineEdit_pname.text()
#年龄
age = int(self.__UI.lineEdit_age.text())
#性别
gender = str(self.__UI.comboBox_gender.currentText())
#联系电话
phone = self.__UI.lineEdit_phone.text()
#是否有诊断结果
result_flag = self.__UI.comboBox_result.currentText()
smoke = self.__UI.comboBox_smoke.currentText()
drink = self.__UI.comboBox_drink.currentText()
trans = self.__UI.comboBox_trans.currentText()
sur = self.__UI.comboBox_sur.currentText()
infect = self.__UI.comboBox_infect.currentText()
aler = self.__UI.comboBox_al.currentText()
data_list.append(pID)
data_list.append(pname)
data_list.append(age)
data_list.append(gender)
data_list.append(phone)
data_list.append(result_flag)
data_list.append(smoke)
data_list.append(drink)
data_list.append(trans)
data_list.append(sur)
data_list.append(infect)
data_list.append(aler)
sql_find = """select count(*) from Patient_table where patient_ID='%s'"""%(pID)
sql = """INSERT INTO Patient_table(patient_ID, name, Age, gender, phone, result, smoke, drink, transfusion,operation, infectious, allergy)
VALUES('%s', '%s', '%d', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s')""" % (pID,pname,age,gender,phone,result_flag,smoke,drink,trans,sur,infect,aler)
return sql_find,sql, data_list
# 记录debug信息
def record_debug(self, debug_message: str) -> None:
self.logger.debug("语句错误,错误原因为{}".format(debug_message))