Python 3.x 如何从Qlistwidget未选中项中删除QPlainTextEdit中匹配的字符串(文本)?

Python 3.x 如何从Qlistwidget未选中项中删除QPlainTextEdit中匹配的字符串(文本)?,python-3.x,pyqt5,qlistwidget,qplaintextedit,qlistwidgetitem,Python 3.x,Pyqt5,Qlistwidget,Qplaintextedit,Qlistwidgetitem,下面是我的示例代码: from PyQt5 import QtCore, QtGui, QtWidgets class Ui_Form(object): def setupUi(self, Form): Form.setObjectName("Form") Form.resize(691, 327) self.listWidget = QtWidgets.QListWidget(Form) self.

下面是我的示例代码:

from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(691, 327)
        self.listWidget = QtWidgets.QListWidget(Form)
        self.listWidget.setGeometry(QtCore.QRect(70, 40, 256, 192))
        self.listWidget.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        self.listWidget.setObjectName("listWidget")
        self.plainTextEdit = QtWidgets.QPlainTextEdit(Form)
        self.plainTextEdit.setGeometry(QtCore.QRect(360, 40, 261, 191))
        self.plainTextEdit.setTabChangesFocus(True)
        self.plainTextEdit.setReadOnly(True)
        self.plainTextEdit.setObjectName("plainTextEdit")

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

        lists = ["one","two","Three"]
        for i in lists:
            item = QtWidgets.QListWidgetItem(i)
            item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable)
            item.setCheckState(QtCore.Qt.Unchecked)
            self.listWidget.addItem(item)

        self.listWidget.itemClicked.connect(self.on_listWidget_itemClicked)

    def on_listWidget_itemClicked(self, item):
        lines = self.plainTextEdit.toPlainText()
        line_list = []
        #if item.listWidget().itemWidget(item) != None: 
        if item.checkState() == QtCore.Qt.Checked:
            self.plainTextEdit.appendPlainText(item.text())
        elif item.checkState() == QtCore.Qt.Unchecked:
            print(item.text())
            
    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    Form = QtWidgets.QWidget()
    ui = Ui_Form()
    ui.setupUi(Form)
    Form.show()
    sys.exit(app.exec_())

在本例中,我将QListWidget与ItemIsUserCheckable和QPlainTextEdit一起使用。我能够使用with复选框将项目从Qlistwidget获取到QPlainTextEdit。如果我在Qlistwidget中选中该项,它就能够将文本设置为QPlaintextEdit。但是当我取消选中项目框时,我想删除QplainTextEdit中的相同文本。例如,如果我选中Qlistwidget中的项目“one”,它将“one”设置到QplainTextEdit中,当我取消选中该项目时,应该删除相同的项目。如果可能的话,有可能吗?

不要修改Qt设计器生成的代码,而是创建另一个继承的类 并使用初始类填充它

from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(691, 327)
        self.listWidget = QtWidgets.QListWidget(Form)
        self.listWidget.setGeometry(QtCore.QRect(70, 40, 256, 192))
        self.listWidget.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        self.listWidget.setObjectName("listWidget")
        self.plainTextEdit = QtWidgets.QPlainTextEdit(Form)
        self.plainTextEdit.setGeometry(QtCore.QRect(360, 40, 261, 191))
        self.plainTextEdit.setTabChangesFocus(True)
        self.plainTextEdit.setReadOnly(True)
        self.plainTextEdit.setObjectName("plainTextEdit")

        self.retranslateUi(Form)
        QtCore.QMetaObject.connectSlotsByName(Form)
          
    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))


class MainWindow(QtWidgets.QWidget, Ui_Form):                             
    def __init__(self):
        super().__init__()
        self.setupUi(self)

        lists = ["one","two","Three"]
        for i in lists:
            item = QtWidgets.QListWidgetItem(i)
            item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable)
            item.setCheckState(QtCore.Qt.Unchecked)
            self.listWidget.addItem(item)
            
#        self.listWidget.itemClicked.connect(self.on_listWidget_itemClicked)

    def on_listWidget_itemClicked(self, item):
        if item.checkState() == QtCore.Qt.Checked:
            self.plainTextEdit.appendPlainText(item.text())
        elif item.checkState() == QtCore.Qt.Unchecked:
            text = self.plainTextEdit.toPlainText()            # 1
            text = text.replace(item.text(), '')               # 2 
            _list = text.split()                               # 3
            text = '\n'.join(_list)                            # 4
            self.plainTextEdit.setPlainText(text)              # 5  


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    Form = MainWindow() #QtWidgets.QWidget()
#    ui = Ui_Form()
#    ui.setupUi(Form)
    Form.show()
    sys.exit(app.exec_())


更新

如果只选中复选框,我们可以这样做吗?我的意思是,当选中复选框时,文本应该附加到明文编辑中。但即使选中该项,它也会附加它

对不起,我忘了在问题中再加一件事。有时,列表中不仅有一个单词,还有两个单词,比如名字和姓氏,也像
列表=[“Fname1 Lname1”,“Fname2 Lname2”,“Fname3 LName3”]
。我们能这样做吗


它在工作。如果只选中复选框,我们可以这样做吗?我的意思是,当选中复选框时,文本应该附加到明文编辑中。但即使选择了项目,它也会附加它。对不起,我忘了在问题中再添加一项。有时,列表中不仅有一个单词,还有两个单词,如名字和姓氏,也有'lists=[“Fname1 Lname1”,“Fname2 Lname2”,“Fname3 LName3”]。我们可以这样做吗?我们可以按照我的要求做吗。如果删除单个单词,单个单词就是删除其他行的单词。例如:有3个项目:1)绿色,2)绿色苹果,3)绿色葡萄。如果从QlistWidget中删除绿色,则将从QPlaintextEdit中的每个项目中删除绿色。我们可以设定这个吗?谢谢你,尼克。有可能吗。如果可能的话,请让我知道。
from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_Form(object):
    def setupUi(self, Form):
        Form.setObjectName("Form")
        Form.resize(691, 327)
        self.listWidget = QtWidgets.QListWidget(Form)
        self.listWidget.setGeometry(QtCore.QRect(70, 40, 256, 192))
        self.listWidget.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
        self.listWidget.setObjectName("listWidget")
        self.plainTextEdit = QtWidgets.QPlainTextEdit(Form)
        self.plainTextEdit.setGeometry(QtCore.QRect(360, 40, 261, 191))
        self.plainTextEdit.setTabChangesFocus(True)
        self.plainTextEdit.setReadOnly(True)
        self.plainTextEdit.setObjectName("plainTextEdit")

        self.retranslateUi(Form)
        QtCore.QMetaObject.connectSlotsByName(Form)
          
    def retranslateUi(self, Form):
        _translate = QtCore.QCoreApplication.translate
        Form.setWindowTitle(_translate("Form", "Form"))


class MainWindow(QtWidgets.QWidget, Ui_Form):                             
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        
        self.lists = {                                                   # !!! self.lists = {...}
            "Fname1 Lname1": 0, 
            "Fname2 Lname2": 0, 
            "Fname3 LName3": 0
        }  
#        lists = ["one", "two", "Three"]
        for i in self.lists.keys():                                       # + .keys()
            item = QtWidgets.QListWidgetItem(i)
            item.setFlags(item.flags() | QtCore.Qt.ItemIsUserCheckable)
            item.setCheckState(QtCore.Qt.Unchecked)
            self.listWidget.addItem(item)
           
#        self.listWidget.itemClicked.connect(self.on_listWidget_itemClicked)

    def on_listWidget_itemClicked(self, item):    
        #                                         +++ vvvvvvvvvvvvvvvvvvvvvvvvvvvv
        if item.checkState() == QtCore.Qt.Checked and self.lists[item.text()] == 0:
            self.plainTextEdit.appendPlainText(item.text())
            self.lists[item.text()] = 1                                   # +
        elif item.checkState() == QtCore.Qt.Unchecked:
            text = self.plainTextEdit.toPlainText()
            text = text.replace(item.text(), '')
#            _list = text.split()              
            _list = text.split('\n')                                      # + '\n'
            _list = [ i for i in _list if i ]                             # +
            text = '\n'.join(_list)              
            self.plainTextEdit.setPlainText(text)   
            self.lists[item.text()] = 0                                   # +


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