【问题标题】:How to drop a file into a QTableWidget in PyQt5如何在 PyQt5 中将文件拖放到 QTableWidget 中
【发布时间】:2019-11-23 06:16:34
【问题描述】:

我正在尝试创建一个表格小部件,我可以在其中放置音频文件并使用文件名、文件大小等填充表格。我的代码如下。我还没有实现在 dragEnterEvent 上读取元数据的部分,因为该表甚至不接受任何类型的丢弃。

from PyQt5 import QtCore, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(982, 615)
        MainWindow.setAcceptDrops(True)
        MainWindow.setStyleSheet("background-color: rgb(255, 255, 255);")
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.label = QtWidgets.QLabel(self.centralwidget)
        self.label.setGeometry(QtCore.QRect(360, 0, 271, 181))
        self.label.setText("")
        self.label.setObjectName("label")
        self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
        self.tableWidget.setGeometry(QtCore.QRect(10, 200, 701, 331))
        self.tableWidget.setAcceptDrops(True)
        self.tableWidget.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        self.tableWidget.setDragDropMode(QtWidgets.QAbstractItemView.DragDrop)
        self.tableWidget.setDefaultDropAction(QtCore.Qt.CopyAction)
        self.tableWidget.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        self.tableWidget.setShowGrid(False)
        self.tableWidget.setSortingEnabled(True)
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.horizontalHeader().setVisible(True)
        self.tableWidget.verticalHeader().setVisible(False)
        self.tableWidget.setRowCount(6)
        self.tableWidget.setColumnCount(6)
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 982, 21))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.titleUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def dragEnterEvent(self, event):
        event.accept()

    def dropEvent(self, event):
        event.accept()

    def titleUi(self, MainWindow):
        MainWindow.setWindowTitle("tableWidget")



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

我怎样才能让桌子接受掉落?

【问题讨论】:

    标签: python file drag-and-drop pyqt5 qtablewidget


    【解决方案1】:

    首先,您应该导入pyuic创建的文件,而不是直接编辑它,否则如果您在Qt Designer中进行进一步的更改,您的所有编辑都将丢失。 (下面的示例代码将展示如何做到这一点)。

    其次,您需要确保该表接受丢弃并指定它可以接收的数据类型。有了它,您就可以监听放置事件并将任何放置的文件添加到表中。

    在使用下面的示例之前,您应该重新运行pyuic。该示例假设 ui 模块将保存为同一目录中的 mainwindow.py。如果您想使用不同的名称,则需要相应地编辑导入行。

    import sys
    from PyQt5 import QtCore, QtWidgets
    from mainwindow import Ui_MainWindow
    
    class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
        def __init__(self):
            super().__init__()
            self.setupUi(self)
            self.setWindowTitle('TableWidget')
            self.tableWidget.setAcceptDrops(True)
            self.tableWidget.viewport().installEventFilter(self)
            types = ['text/uri-list']
            types.extend(self.tableWidget.mimeTypes())
            self.tableWidget.mimeTypes = lambda: types
            self.tableWidget.setRowCount(0)
    
        def eventFilter(self, source, event):
            if (event.type() == QtCore.QEvent.Drop and
                event.mimeData().hasUrls()):
                for url in event.mimeData().urls():
                    self.addFile(url.toLocalFile())
                return True
            return super().eventFilter(source, event)
    
        def addFile(self, filepath):
            row = self.tableWidget.rowCount()
            self.tableWidget.insertRow(row)
            item = QtWidgets.QTableWidgetItem(filepath)
            self.tableWidget.setItem(row, 0, item)
            self.tableWidget.resizeColumnToContents(0)
    
    if __name__ == '__main__':
    
        app = QtWidgets.QApplication(sys.argv)
        window = MainWindow()
        window.show()
        sys.exit(app.exec_())
    

    【讨论】:

    • 非常感谢!几天来一直在为此苦苦挣扎。您推荐的任何好的资源我都可以查看以了解有关 pyqt 的更多信息?我发现大多数书籍只涉及基础知识,尽管 Qt 文档深入,但我很难理解和翻译用于 python 的 C++ 代码。跨度>
    • @West zetcode PyQt5 tutorial 会给你一个很好的基本概述。有several books listed here(但我没有任何建议)。就个人而言,我认为一旦你掌握了基础知识,Qt 文档就是你所需要的。大多数 C++ 示例已移植到 PyQt5,可以是 found herelatest source code。对于任何剩余的差距,请在 SO 上提问。
    猜你喜欢
    • 2012-05-03
    • 2018-02-17
    • 1970-01-01
    • 2014-12-01
    • 2018-06-15
    • 1970-01-01
    • 2021-06-04
    • 2011-08-05
    • 2013-04-21
    相关资源
    最近更新 更多