【问题标题】:How to get selected item in table using pyqt?如何使用pyqt获取表格中的选定项目?
【发布时间】:2014-04-09 15:30:53
【问题描述】:

我在 mysql 数据库的表中显示数据, 之后,我想当单击表中的行时,它将打印行中的值,即打印数据库中现有数据的 id。我怎样才能让它变成那样?

这里是源代码:

from PyQt4 import QtCore, QtGui
import sys
import MySQLdb
from form.DBConnection import Connection
import MySQLdb as mdb
db = Connection()
myCursor = db.name().cursor()

".................................................. .. .....................”

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName(_fromUtf8("MainWindow"))
        MainWindow.resize(655, 356)
        self.centralwidget = QtGui.QWidget(MainWindow)
        self.centralwidget.setObjectName(_fromUtf8("centralwidget"))
        self.tbl_anggota = QtGui.QTableWidget(self.centralwidget)
        self.tbl_anggota.setGeometry(QtCore.QRect(15, 40, 511, 192))
        self.tbl_anggota.setObjectName(_fromUtf8("tbl_anggota"))
        self.tbl_anggota.setColumnCount(3)
        self.tbl_anggota.setRowCount(0)
        item = QtGui.QTableWidgetItem()
        self.tbl_anggota.setHorizontalHeaderItem(0, item)
        item = QtGui.QTableWidgetItem()
        self.tbl_anggota.setHorizontalHeaderItem(1, item)
        item = QtGui.QTableWidgetItem()
        self.tbl_anggota.setHorizontalHeaderItem(2, item)
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtGui.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 655, 21))
        self.menubar.setObjectName(_fromUtf8("menubar"))
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtGui.QStatusBar(MainWindow)
        self.statusbar.setObjectName(_fromUtf8("statusbar"))
        MainWindow.setStatusBar(self.statusbar)
        self.retranslateUi(MainWindow)
        self.table(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow", None))
        item = self.tbl_anggota.horizontalHeaderItem(0)
        item.setText(_translate("MainWindow", "NIM", None))
        item = self.tbl_anggota.horizontalHeaderItem(1)
        item.setText(_translate("MainWindow", "NAMA", None))
        item = self.tbl_anggota.horizontalHeaderItem(2)

    def table(self, MainWindow):
        myCursor.execute("SELECT * FROM anggota")
        jum_baris= myCursor.fetchall()
        self.tbl_anggota.setRowCount(len(jum_baris)) 
        self.tbl_anggota.setColumnCount(3) 
        for i in range (len(jum_baris)):
            for j in range (3):
                item = Qt.QTableWidgetItem('%s' % (jum_baris[i][j + 1]))
                self.tbl_anggota.setItem(i, j, item)


if __name__ == "__main__":
    app = QtGui.QApplication(sys.argv)
    MainWindow = QtGui.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

【问题讨论】:

    标签: python mysql database selecteditem


    【解决方案1】:

    这行代码会选择current row

    r = self.tbl_anggota.currentRow()
    

    如果您知道您的列(即它不是动态的),那么您可以通过执行以下操作来提取每个单元格的值:

    field1 = self.tbl_anggota.item(r,0).text()
    field2 = self.tbl_anggota.item(r,1).text()
    

    在这种情况下,item 调用中的 01 是您的列,位于索引为 0 的数组中。请记住,隐藏的列仍然很重要。

    要在单击一行时自动执行此操作,您需要使用信号 itemClicked

    【讨论】:

    • 我不明白源代码怎么放,我想在点击的时候立即打印结果,例如数据库的数据id的结果
    • 你明白哪一部分是怎么做的吗?
    • 对不起,我不明白
    • 听起来您需要阅读有关 PyQt 信号和插槽的快速教程。这种解释很长时间才能添加到我的答案中。
    猜你喜欢
    • 2018-04-22
    • 2011-08-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-01-23
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多