【无标题】pyqt qlistview 实现自动完成

该代码实现了一个使用PySide6库的GUI应用,它包含一个文本编辑器和列表视图。用户输入文本后,程序会实时过滤并显示匹配的Excel数据。双击列表项可记录选择,信息定时写入新的Excel文件,支持不同等级的数据分类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

#!/usr/bin/env python
# coding: utf-8


from PySide6.QtWidgets import (
QApplication,
QMainWindow,
QWidget,
QListView,
QComboBox,
QTextEdit)

from PySide6.QtGui import QStandardItem, QStandardItemModel
from PySide6.QtUiTools import QUiLoader

from PySide6.QtCore import (
QFile,
QIODevice,
QAbstractListModel,
QModelIndex,
QTimer)

import sys
from collections import deque
import pandas as pd


class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("My App")
        self.ui=QFile(r'ui2.ui')
        self.ui.open(QIODevice.ReadOnly)
        loader=QUiLoader()
        self.window=loader.load(self.ui)
        
        self.et=self.window.findChild(QTextEdit, 'txt')
        self.et.textChanged.connect(self.delay)
    
    
        self.lv=self.window.findChild(QListView, 'listView')
        
        # read word
        self.df = pd.read_excel('word2.xlsx', engine='openpyxl')
        self.model = QStandardItemModel()
        
        self.lv.setModel(self.model)
        self.lv.doubleClicked[QModelIndex].connect(self.item_clicked)
        
        self.timer = QTimer()
        self.timer.setSingleShot (True)
        self.timer.timeout.connect(self.txt_changed)
        
        self.timer_write = QTimer()
        self.timer_write.timeout.connect(self.write_out)
        self.timer_write.start(1000)
        
        # result data
        self.words = []
        self.queue = deque()
        self.grade0 = "G2"
        self.grade = self.window.findChild(QComboBox, 'grade')
        self.grade.addItem('G1')
        self.grade.addItem('G2')
        self.grade.addItem('G3')
        
    def show(self):
        self.window.show()        
        
    # 延时0.2秒查询
    def delay(self):
        self.timer.stop()
        self.timer.start(200)
    
    def txt_changed(self): 
        txt = self.et.toPlainText()
        self.model.clear()
        if txt != '':
            records = self.df[self.df['text'].str.contains(txt)]
            for i,v in records.iterrows():
                self.model.appendRow(QStandardItem(v['text']))

    # 双击条目,记录    
    def item_clicked(self, index):
        item = self.model.itemFromIndex(index)
        print(item.text())
        self.words.append(item.text())
        self.queue.append(1)

    # 写出
    def write_out(self):
        if len(self.queue) >= 1:            
            words = list(set(self.words))
            df = pd.DataFrame({'text': words})
            # print(df)
            df.to_excel('word_%s.xlsx' % self.grade.currentText(), sheet_name=self.grade.currentText())
            self.queue.pop()

if __name__ == '__main__':
    app=QApplication()
    m=MainWindow()
    m.show()
 
    app.exec()






PyQt中,你可以使用QListWidget或QListView实现删除item的操作。首先,你需要获取选中的item的索引,然后使用takeItem()方法将其从列表中删除。具体的步骤如下: 1. 获取QListView的选中项的索引。 2. 使用model()方法获取QListView的模型对象。 3. 使用removeRow()方法从模型中删除选中的行。 4. 刷新QListView以更新显示。 下面是一个示例代码: ```python # 获取选中项的索引 selected_indexes = listView.selectedIndexes() # 获取模型对象 model = listView.model() # 逐个删除选中的item for index in selected_indexes: # 获取行号 row = index.row() # 从模型中删除选中的行 model.removeRow(row) # 刷新QListView listView.update() ``` 请注意,这个示例假设你已经创建了一个名为`listView`的QListView对象,并且已经将其与一个模型对象关联。你可以根据自己的实际情况进行相应的调整。 参考资料: QListWidget Documentation: https://doc.qt.io/qt-5/qlistwidget.html QListView Documentation: https://doc.qt.io/qt-5/qlistview.html QAbstractItemModel Documentation: https://doc.qt.io/qt-5/qabstractitemmodel.html<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [QListView自定义Item](https://blog.youkuaiyun.com/a844651990/article/details/84324560)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

容沁风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值