tablewidget.setitem
时间: 2023-04-22 15:06:46 浏览: 346
tablewidget.setItem是Qt中的一个函数,用于设置QTableWidget中的单元格的内容。它的参数包括行、列、单元格内容以及单元格的属性等。通过调用这个函数,可以方便地对QTableWidget进行操作和管理。
相关问题
else: item1 = menu.addAction(u"Return") action = menu.exec_(self.tableWidget.mapToGlobal(pos)) if self.tableWidget.rowCount() > 0: if action == item1: order_id = self.tableWidget.item(self.tableWidget.currentRow(), 0).text() sql = 'call book_return(%s)' self.sql_cursor.execute(sql, [order_id]) if self.sql_cursor.fetchall()[0][0] == '1': self.user_info_get() self.table_refresh_2() else: QMessageBox.information(self, "Remind", "The book has been returned!") def fun(self): if self.comboBox.currentIndex() == 0: if self.lineEdit.text() == '': self.table_refresh() else: self.boot_info_ret(self.lineEdit.text()) elif self.comboBox.currentIndex() == 1: self.table_refresh_2() def boot_info_ret(self, value): sql = [ "select * from book where locate(%s,book_name) > 0", "select * from book where locate(%s,editor) > 0", "select * from book where locate(%s,publisher) > 0" ] result = [] i = 0 while len(result) == 0 and i < 3: self.sql_cursor.execute(sql[i], value) result = self.sql_cursor.fetchall() i += 1 if len(result) == 0: QMessageBox.information(self, "Remind", "No relevant information was retrieved!") else: self.tableWidget.setColumnCount(7) self.tableWidget.setHorizontalHeaderLabels( ['Book number', 'Name', 'Writer', 'Publishing house', 'Number of books in collection', 'Number of pavilions', 'Pressmark']) rowlength = self.tableWidget.rowCount() for i in range(0, rowlength): self.tableWidget.removeRow(0) for i in range(len(result)): self.tableWidget.insertRow(i) self.tableWidget.setItem(i, 0, QTableWidgetItem(str(result[i][0]))) self.tableWidget.setItem(i, 1, QTableWidgetItem(result[i][1])) self.tableWidget.setItem(i, 2, QTableWidgetItem(result[i][2])) self.tableWidget.setItem(i, 3, QTableWidgetItem(str(result[i][3]))) self.tableWidget.setItem(i, 4, QTableWidgetItem(str(result[i][4]))) self.tableWidget.setItem(i, 5, QTableWidgetItem(str(result[i][5]))) self.tableWidget.setItem(i, 6, QTableWidgetItem(str(result[i][6]))) self.tableWidget.resizeColumnsToContents()每一行代码的意义和作用
这是一段 Python 代码,主要是实现一个图书馆管理系统的功能。下面是每一行代码的含义和作用:
```python
else: item1 = menu.addAction(u"Return") action = menu.exec_(self.tableWidget.mapToGlobal(pos))
```
这是一个条件语句,当不满足前一个条件时执行,定义了一个菜单项 item1,然后显示一个菜单。当用户在菜单中选择了一个操作,会将该操作赋值给 action。
```python
if self.tableWidget.rowCount() > 0:
if action == item1:
order_id = self.tableWidget.item(self.tableWidget.currentRow(), 0).text()
sql = 'call book_return(%s)'
self.sql_cursor.execute(sql, [order_id])
if self.sql_cursor.fetchall()[0][0] == '1':
self.user_info_get()
self.table_refresh_2()
else:
QMessageBox.information(self, "Remind", "The book has been returned!")
```
这是一个条件语句,判断表格中是否有数据,如果有,则根据用户选择的操作来执行不同的代码。如果用户选择了菜单项 item1,将获取当前行的书籍编号 order_id,并执行一个 SQL 查询,然后根据查询结果进行不同的操作。
```python
def fun(self):
if self.comboBox.currentIndex() == 0:
if self.lineEdit.text() == '':
self.table_refresh()
else:
self.boot_info_ret(self.lineEdit.text())
elif self.comboBox.currentIndex() == 1:
self.table_refresh_2()
```
这是一个函数,用于根据用户选择的下拉列表框中的选项来刷新表格。如果选项为0,则根据输入框中的内容进行模糊查询;如果选项为1,则刷新表格显示所有书籍信息。
```python
def boot_info_ret(self, value):
sql = [ "select * from book where locate(%s,book_name) > 0",
"select * from book where locate(%s,editor) > 0",
"select * from book where locate(%s,publisher) > 0" ]
result = []
i = 0
while len(result) == 0 and i < 3:
self.sql_cursor.execute(sql[i], value)
result = self.sql_cursor.fetchall()
i += 1
if len(result) == 0:
QMessageBox.information(self, "Remind", "No relevant information was retrieved!")
else:
self.tableWidget.setColumnCount(7)
self.tableWidget.setHorizontalHeaderLabels( ['Book number', 'Name', 'Writer', 'Publishing house', 'Number of books in collection', 'Number of pavilions', 'Pressmark'])
rowlength = self.tableWidget.rowCount()
for i in range(0, rowlength):
self.tableWidget.removeRow(0)
for i in range(len(result)):
self.tableWidget.insertRow(i)
self.tableWidget.setItem(i, 0, QTableWidgetItem(str(result[i][0])))
self.tableWidget.setItem(i, 1, QTableWidgetItem(result[i][1]))
self.tableWidget.setItem(i, 2, QTableWidgetItem(result[i][2]))
self.tableWidget.setItem(i, 3, QTableWidgetItem(str(result[i][3])))
self.tableWidget.setItem(i, 4, QTableWidgetItem(str(result[i][4])))
self.tableWidget.setItem(i, 5, QTableWidgetItem(str(result[i][5])))
self.tableWidget.setItem(i, 6, QTableWidgetItem(str(result[i][6])))
self.tableWidget.resizeColumnsToContents()
```
这是一个函数,用于根据输入的关键字进行模糊查询,并将查询结果显示在表格中。根据用户输入的内容,依次执行三个 SQL 查询语句,直到查询到结果为止。查询结果以列表形式返回,然后将结果显示在表格中。
```python
self.user_info_get()
```
这是一个函数,用于获取用户信息。
rows = cur.fetchall() self.tableWidget.setRowCount(len(rows)) for i, row in enumerate(rows): for j, value in enumerate(row): if j == 0: value = os.path.basename(value) item = QTableWidgetItem(str(value)) self.tableWidget.setItem(i, j, item) else: item = QTableWidgetItem(str(value)) self.tableWidget.setItem(i, j, item)
这段代码是将从数据库中查询到的数据展示在 GUI 界面的表格中,具体来说,它执行了以下操作:
1. 使用 `cur.fetchall()` 获取查询结果集中的所有行数据,并将其存储在 `rows` 变量中。
2. 使用 `self.tableWidget.setRowCount(len(rows))` 设置表格中的行数为查询结果集中的行数。
3. 使用 `enumerate()` 函数遍历查询结果集中的每一行数据,并将其填充到表格中。在遍历行数据时,使用 `enumerate()` 函数获取行号 `i`,并将其作为表格中的行索引。然后,再使用 `enumerate()` 函数遍历该行数据中的每一个字段,并将其填充到表格中。
4. 对于每一个字段,如果是第一个字段,即 `j == 0` 时,使用 `os.path.basename()` 函数获取文件名,并将其作为字符串类型的 `value` 存储在 `item` 变量中。否则,直接将该字段值存储在 `item` 变量中。
5. 最后,使用 `self.tableWidget.setItem(i, j, item)` 将 `item` 变量中的值设置为表格中的单元格值。