def query(self, sql): self. # 执行 SQL 查询语句 self.cursor.execute(sql) # 创建一个新窗口,并设置其属性 new_window = QWidget(self) new_window.setWindowTitle("查询员工信息") new_window.setGeometry(200, 200, 400, 300) # 创建返回按钮并设置其属性 return_button = QPushButton("返回", new_window) return_button.clicked.connect(new_window.close) # 获取查询结果并显示在表格中 rows = self.cursor.fetchall() self.table = QTableWidget() if rows: self.table.setRowCount(len(rows)) self.table.setColumnCount(len(rows[0])) for i, row in enumerate(rows): for j, col in enumerate(row): item = QTableWidgetItem(str(col)) self.table.setItem(i, j, item) self.table.setHorizontalHeaderLabels(["部门", "姓名", "性别", '职位', '工号', '状态']) self.table.horizontalHeader().setVisible(True) self.input_box = QLineEdit(new_window) # 修改状态标签的内容 self.status_label.setText("输入需要查询的数据,格式为:部门/姓名/性别/职位/工号/状态,对象") self.v_layout = QVBoxLayout(new_window) self.v_layout.addWidget(self.input_box) # 单个查询按键 query_button = QPushButton("单个查询", new_window) query_button.clicked.connect(lambda: self.query_data(new_window)) # 添加表格、按键到新窗口中 self.v_layout.addWidget(self.table) self.v_layout.addWidget(query_button) self.v_layout.addWidget(return_button) new_window.setLayout(self.v_layout) new_window.show() 如何关闭父窗口
时间: 2024-02-14 21:06:43 浏览: 91
在这段代码中,关闭父窗口的方式取决于您实例化主窗口的方式。如果您的主窗口是通过`QMainWindow`类创建的,可以使用以下代码关闭父窗口:
```python
self.close()
```
如果您的主窗口是通过`QWidget`类创建的,可以使用以下代码关闭父窗口:
```python
self.parent().close()
```
请注意,这两个方法都会关闭父窗口及其所有子窗口。如果您只想关闭父窗口而不关闭子窗口,请使用以下代码:
```python
self.parent().hide()
```
这将隐藏父窗口,但不会关闭它。
相关问题
def query(self, sql): # 执行 SQL 查询语句 self.cursor.execute(sql) # 获取查询结果并显示在表格中 rows = self.cursor.fetchall() if rows: self.table.setRowCount(len(rows)) self.table.setColumnCount(len(rows[0])) for i, row in enumerate(rows): for j, col in enumerate(row): item = QTableWidgetItem(str(col)) self.table.setItem(i, j, item)如何设置表格每列的名字
你可以使用 `setHorizontalHeaderLabels` 方法来设置表格每列的名字。例如,如果你想将表格的第一列命名为 "姓名",第二列命名为 "年龄",第三列命名为 "性别",你可以这样写:
```
self.table.setHorizontalHeaderLabels(["姓名", "年龄", "性别"])
```
将上述代码放到 `query` 方法中,在设置表格数据之前调用即可。
def query(self, sql): self.table = QTableWidget() self.setCentralWidget(self.table) self.v_layout.addWidget(self.table) # 执行 SQL 查询语句 self.cursor.execute(sql) # 获取查询结果并显示在表格中 rows = self.cursor.fetchall() if rows: self.table.setRowCount(len(rows)) self.table.setColumnCount(len(rows[0])) for i, row in enumerate(rows): for j, col in enumerate(row): item = QTableWidgetItem(str(col)) self.table.setItem(i, j, item) self.table.setHorizontalHeaderLabels(["部门", "姓名", "性别",'职位','工号','状态']) self.table.horizontalHeader().setVisible(True)无法显示内容
这段代码看起来是将数据库查询结果显示在 PyQt5 的 QTableWidget 中。如果您在运行代码时无法在应用程序界面中看到表格的内容,请检查以下几点:
1. 是否正确连接了数据库,且 SQL 查询语句正确执行;
2. 是否正确设置了 QTableWidget 的大小和位置,以及它的父窗口;
3. 是否正确添加了表格的表头信息;
4. 是否正确添加了表格的每一个单元格的内容。
如果您仍然无法解决问题,请提供更多详细信息和完整代码,以便我可以帮助您解决问题。
阅读全文
相关推荐















