python tableview添加内容_如何在Python PyQt4 TableView中以编程方式更改/更新数据?

我希望在QWidget窗口中有一个表,并在用户每次在lineEdit字段中输入值时更新该表。我该如何以编程的方式完成这项工作?

状态:您的代码出现以下错误:TypeError: QAbstractTableModel.beginInsertRows(QModelIndex, int, int):

argument 2 has unexpected type 'str'from PyQt4 import QtGui , QtCore

import sys

try:

_fromUtf8 = QtCore.QString.fromUtf8

except AttributeError:

_fromUtf8 = lambda s: s

class ABCTableModel(QtCore.QAbstractTableModel):

def __init__(self,data,parent=None):

QtCore.QAbstractTableModel.__init__(self,parent)

self.__data=data # Initial Data

def rowCount( self, parent ):

return len(self.__data)

def columnCount( self , parent ):

return len(self.__data)

def data ( self , index , role ):

if role == QtCore.Qt.DisplayRole:

row = index.row()

column = index.column()

value = self.__data[row][column]

return QtCore.QString(str(value))

def setData(self, index, value):

self.__data[index.row()][index.column()] = value

return True

def flags(self, index):

return QtCore.Qt.ItemIsEnabled|QtCore.Qt.ItemIsEditable|QtCore.Qt.ItemIsSelectable

def insertRows(self , position , rows , item , parent=QtCore.QModelIndex()):

# beginInsertRows (self, QModelIndex parent, int first, int last)

self.beginInsertRows(QtCore.QModelIndex(),position,position)

self.__data.append(item) # Item must be an array

self.endInsertRows()

return True

class Ui_MainWindow(QtGui.QMainWindow , QtGui.QWidget):

def __init__(self):

QtGui.QMainWindow.__init__(self,None)

QtGui.QWidget.__init__(self,None)

def setupUi(self, MainWindow):

self.centralwidget = QtGui.QWidget(MainWindow)

self.centralwidget.setObjectName(_fromUtf8("centralwidget"))

self.tableView = QtGui.QTableView(self.centralwidget)

self.tableModel=ABCTableModel([[1,2,3],[2,3,4],[4,5,6]])

self.tableView.setModel(self.tableModel)

self.lineEdit_1 = QtGui.QLineEdit(self.centralwidget)

self.lineEdit_2 = QtGui.QLineEdit(self.centralwidget)

self.lineEdit_3 = QtGui.QLineEdit(self.centralwidget)

self.tableModel.insertRows(self.lineEdit_1.text(),self.lineEdit_2.text(), self.lineEdit_3.text())

if __name__ == "__main__":

app = QtGui.QApplication(sys.argv)

MainWindow = QtGui.QMainWindow() #

ui = Ui_MainWindow()

ui.setupUi(MainWindow)

MainWindow.show()

sys.exit(app.exec_())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
auto& stu : students) { if (stu.score == score) { res.push_back(stu); } } 在PyQt中,可以通过以下步骤获取用户在TableView上修改的数据: 1. 建立一个数据模型,如QStandardItemModel。 2. 将数据模型设置为TableView的模型,使用setModel()方法。 3. 为每一 return res; } private: vector<Student> students; // 学生信息列表 }; int main() { StudentManager sm列设置一个信号-槽连接,以便在用户编辑单元格时触发槽函数。 4. 在槽函数中; // 添加学生信息 Student s1 = {"计算机学院", "计算机科学与技术,使用data()方法获取用户编辑后的数据。 下面是一个简单的示例代码: ```python from PyQt5.QtWidgets import QApplication, QTableView, QStandardItemModel from PyQt5.QtCore import Qt app = QApplication([]) model = QStandardItemModel", "2019级1班", "20190101", "张三", "男", 175.0f, "篮(4, 2) model.setHorizontalHeaderLabels(['Name', 'Age']) view = QTableView() view.setModel(model) # 设置信号球", "本科生", 5000.0f, 90.0f}; sm.addStudent(s1); Student-槽连接 view.clicked.connect(lambda index: print(model.data(index, Qt.DisplayRole))) # 设置数据 model.setData(model.index(0 s2 = {"计算机学院", "计算机科学与技术", "2019级2班", "201, 0), 'Alice') model.setData(model.index(0, 1), '25') model.setData(model.index(1, 0), 'Bob') model.setData(model.index(1, 1), '30') view.show() app.exec_() ``` 在这个示90102", "李四", "女", 165.0f, "足球", "本科生", 6000例中,我们创建了一个4行2列的数据模型,并将其设置为TableView的模型。我们设置了一个.0f, 85.0f}; sm.addStudent(s2); // 按照不同条件查询学生信息 信号-槽连接,当用户在TableView上单击单元格时,将触发一个槽函数并打印出该 vector<Student> res1 = sm.queryByCollege("计算机学院"); for (auto& s : res1) { 单元格的数据。最后,我们设置了一些示例数据并显示TableView。 当用户在TableView编辑单元 cout << s.name << " " << s.major << " " << s.clazz << endl; } vector<Student> res2格时,槽函数将被触发,并使用data()方法获取用户编辑后的数据。你可以修改槽函数来执行任 = sm.queryByHobby("篮球"); for (auto& s : res2) { cout << s.name << " "何你需要的操作,例如将数据保存到数据库中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值