def add_data(self): # 创建一个新窗口,并设置其属性 new_window = QWidget(self) new_window.setWindowTitle("添加员工信息") new_window.setGeometry(200, 200, 400, 300) # 创建返回按钮并设置其属性 return_button = QPushButton("返回", new_window) return_button.setGeometry(10, 10, 50, 30) return_button.clicked.connect(new_window.close) self.input_box = QLineEdit() self.input_box.setPlaceholderText("输入数据,格式为:部门,姓名,性别,职位,工号,状态") self.v_layout.addWidget(self.input_box) # 获取输入框中的数据 data = self.input_box.text().split(",") if len(data) != 6: self.status_label.setText("输入格式错误!请按照 部门,姓名,性别,职位,工号,状态 的格式输入。") return # 执行 SQL 插入语句 sql = "INSERT INTO mytable (部门, 姓名, 性别, 职位, 工号, 状态) VALUES (?, ?, ?, ?, ?, ?)" try: self.cursor.execute(sql, data) self.cnxn.commit() self.query("SELECT * FROM Staff") self.status_label.setText("数据添加成功!") except: self.status_label.setText("数据添加失败!") new_window.setLayout(self.v_layout) new_window.show() self.hide() # 隐藏父窗口查错
时间: 2024-01-13 12:05:23 浏览: 81
这段代码中,在新窗口中创建了一个返回按钮,并将其绑定到关闭新窗口的事件上,但是在获取输入框中的数据时,应该在点击添加按钮时获取,而不是在创建新窗口时就获取。因此,需要将获取数据的代码移到点击添加按钮的事件中。另外,应该在执行完插入语句后再显示新窗口,否则新窗口会在数据插入之前就显示出来。修改后的代码如下:
```
def add_data(self):
# 创建一个新窗口,并设置其属性
new_window = QWidget(self)
new_window.setWindowTitle("添加员工信息")
new_window.setGeometry(200, 200, 400, 300)
# 创建返回按钮并设置其属性
return_button = QPushButton("返回", new_window)
return_button.setGeometry(10, 10, 50, 30)
return_button.clicked.connect(new_window.close)
self.input_box = QLineEdit()
self.input_box.setPlaceholderText("输入数据,格式为:部门,姓名,性别,职位,工号,状态")
self.v_layout.addWidget(self.input_box)
add_button = QPushButton("添加", new_window)
add_button.setGeometry(300, 10, 50, 30)
add_button.clicked.connect(lambda: self.insert_data(new_window))
new_window.setLayout(self.v_layout)
new_window.show()
self.hide() # 隐藏父窗口
def insert_data(self, new_window):
# 获取输入框中的数据
data = self.input_box.text().split(",")
if len(data) != 6:
self.status_label.setText("输入格式错误!请按照 部门,姓名,性别,职位,工号,状态 的格式输入。")
return
# 执行 SQL 插入语句
sql = "INSERT INTO mytable (部门, 姓名, 性别, 职位, 工号, 状态) VALUES (?, ?, ?, ?, ?, ?)"
try:
self.cursor.execute(sql, data)
self.cnxn.commit()
self.query("SELECT * FROM Staff")
self.status_label.setText("数据添加成功!")
new_window.show() # 在插入数据后再显示新窗口
except:
self.status_label.setText("数据添加失败!")
```
阅读全文