tableWidget.setSortingEnabled(False)怎么使用
时间: 2024-03-30 19:36:57 浏览: 35
这段代码用于禁用QTableWidget中的排序功能。要使用它,需要先创建一个QTableWidget对象,然后调用setSortingEnabled(False)方法来禁用排序功能,示例代码如下:
```
from PyQt5.QtWidgets import QApplication, QTableWidget
app = QApplication([])
tableWidget = QTableWidget()
tableWidget.setSortingEnabled(False)
```
在上面的代码中,我们创建了一个QApplication对象和一个QTableWidget对象,并使用setSortingEnabled(False)方法来禁用QTableWidget中的排序功能。
相关问题
from PyQt5 import QtCore, QtGui, QtWidgets class Ui_Form2(object): def setupUi(self, Form): Form.setObjectName("Form") Form.resize(760, 605) self.label = QtWidgets.QLabel(Form) self.label.setGeometry(QtCore.QRect(310, 10, 171, 20)) font = QtGui.QFont() font.setFamily("Agency FB") font.setPointSize(8) self.label.setFont(font) self.label.setObjectName("label") self.tableWidget = QtWidgets.QTableWidget(Form) self.tableWidget.setGeometry(QtCore.QRect(10, 40, 750, 600)) self.tableWidget.setObjectName("tableWidget") self.tableWidget.setColumnCount(8) self.tableWidget.setRowCount(13) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(0, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(1, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(2, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(3, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(4, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(5, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(6, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(7, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(8, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(9, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(10, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(11, item) item = QtWidgets.QTableWidgetItem() self.tableWidget.setVerticalHeaderItem(12, item) item = QtWidgets.QTableWidgetItem()
这段代码是使用 PyQt5 框架创建一个窗口应用程序,并在窗口上添加一个 QTableWidget 表格控件。在表格控件中,设置了 8 列 13 行的表格,并为每一行设置了一个 QTableWidgetItem 对象,用于显示表格中每个单元格的内容。该代码可以在 PyQt5 应用程序中作为一个 UI 界面的一部分使用。需要注意的是,这段代码只是该界面的一部分,完整的界面代码可能还包括其他部分。
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()
```
这是一个函数,用于获取用户信息。
阅读全文