Выберите текст в PYQT для копирования - PullRequest
0 голосов
/ 24 апреля 2020

Я разработал настольное приложение windows с QT Designer и PYQT5. Проблема в том, что я не могу выбрать какой-либо элемент, текст в главном окне или на qtablewidget, чтобы вставить его вручную в другое место. Это облегчит пользователям, а не мне. `

from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(800, 600)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
        self.tableWidget.setGeometry(QtCore.QRect(260, 160, 256, 192))
        self.tableWidget.setRowCount(3)
        self.tableWidget.setColumnCount(2)
        self.tableWidget.setObjectName("tableWidget")
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setItem(1, 0, item)
        self.input_gunduz = QtWidgets.QLineEdit(self.centralwidget)
        self.input_gunduz.setGeometry(QtCore.QRect(370, 70, 71, 20))
        self.input_gunduz.setObjectName("input_gunduz")
        self.label_5 = QtWidgets.QLabel(self.centralwidget)
        self.label_5.setGeometry(QtCore.QRect(220, 70, 101, 21))
        font = QtGui.QFont()
        font.setPointSize(9)
        font.setBold(True)
        font.setWeight(75)
        self.label_5.setFont(font)
        self.label_5.setObjectName("label_5")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

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

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        __sortingEnabled = self.tableWidget.isSortingEnabled()
        self.tableWidget.setSortingEnabled(False)
        item = self.tableWidget.item(1, 0)
        item.setText(_translate("MainWindow", "trial"))
        self.tableWidget.setSortingEnabled(__sortingEnabled)
        self.label_5.setText(_translate("MainWindow", "Gündüz (kWhr):"))


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_())

`

Код, как показано выше. Пожалуйста, помогите мне сделать главное окно выбираемым

1 Ответ

0 голосов
/ 24 апреля 2020

Копирование текста не работает одинаково для каждого виджета, потому что каждый тип виджета использует даже радикально разные способы отображения или взаимодействия с текстом.

Если вы хотите скопировать текст QLabel, вы должны сделать его выбираемым (используя label.setTextInteractionFlags(Qt.TextSelectableByMouse)).

Но если вы хотите скопировать текст из QTableWidget, все будет по-другому, так как таблица позволяет взаимодействовать с их элементами которые препятствуют простому выделению текста.

Очевидно, что наиболее простым способом было бы начать редактирование элемента (при условии, что он редактируемый) и выбрать его текст, но если вам нужны другие способы сделать это, это зависит от как вы хотите иметь возможность копировать текст.

Возможно использование сочетания клавиш ctrl + c. Для этого нам нужно установить фильтр событий на виджет таблицы:

from PyQt5 import QtCore, QtGui, QtWidgets
from mainwindow import Ui_MainWindow

class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)

        # install an event filter on the table widget, so that we can filter all
        # its event, including keyboard presses
        self.tableWidget.installEventFilter(self)

    def eventFilter(self, source, event):
        if event.type() == QtCore.QEvent.KeyPress and event == QtGui.QKeySequence.Copy:
            # check if an index is currently selected and it has text
            text = self.tableWidget.currentIndex().data()
            if text:
                # copy that text to the clipboard
                QtWidgets.QApplication.clipboard().setText(text)
        return super().eventFilter(source, event)

if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())

Обратите внимание, что в примере выше я использовал метод множественного наследования, описанный в документации о с использованием Designer с пользовательскими файлами. Вы должны никогда редактировать файлы, созданные с помощью pyuic.

Также можно установить меню для виджета таблицы и скопировать оттуда текст:

class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self):
        # ...

        # use the custom context menu policy for the table widget, so that we can
        # connect the menu request to a slot
        self.tableWidget.setContextMenuPolicy(QtCore.Qt.CustomContextMenu)
        self.tableWidget.customContextMenuRequested.connect(self.showTableMenu)

    def showTableMenu(self, pos):
        # get the text of the index at the mouse cursor (if any)
        text = self.tableWidget.indexAt(pos).data()
        menu = QtWidgets.QMenu()
        copyAction = menu.addAction('Copy')
        if not text:
            copyAction.setEnabled(False)
        # show the menu
        res = menu.exec_(QtGui.QCursor.pos())
        if res == copyAction:
            # if the menu has been triggered by the action, copy to the clipboard
            QtWidgets.QApplication.clipboard().setText(text)
...