首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

是否有一个PyQt表格/列表视图可以在其中一列中使用组合框动态填充?

是的,PyQt提供了一个名为QComboBox的组件,可以在表格/列表视图的一列中使用它来实现动态填充。QComboBox是一个下拉列表框,可以显示一个可选项列表,并允许用户从中选择一个选项。

要在表格/列表视图的一列中使用QComboBox,可以使用QItemDelegate类来自定义该列的显示和编辑方式。首先,创建一个自定义的QItemDelegate子类,并重写createEditor()方法来创建QComboBox作为编辑器。然后,重写setEditorData()方法来设置QComboBox的选项列表和当前选中的选项。最后,重写setModelData()方法来将用户选择的选项保存回数据模型。

以下是一个示例代码,演示如何在表格/列表视图的一列中使用QComboBox动态填充:

代码语言:txt
复制
from PyQt5.QtWidgets import QApplication, QTableView, QComboBox, QStyledItemDelegate
from PyQt5.QtCore import Qt

class ComboBoxDelegate(QStyledItemDelegate):
    def createEditor(self, parent, option, index):
        combo_box = QComboBox(parent)
        combo_box.addItem("Option 1")
        combo_box.addItem("Option 2")
        combo_box.addItem("Option 3")
        return combo_box

    def setEditorData(self, editor, index):
        current_text = index.data(Qt.EditRole)
        editor.setCurrentText(current_text)

    def setModelData(self, editor, model, index):
        selected_text = editor.currentText()
        model.setData(index, selected_text, Qt.EditRole)

app = QApplication([])
table_view = QTableView()
table_view.setItemDelegateForColumn(0, ComboBoxDelegate())
table_view.show()
app.exec_()

在上述示例中,我们创建了一个名为ComboBoxDelegate的自定义QItemDelegate子类。在createEditor()方法中,我们创建了一个QComboBox作为编辑器,并添加了三个选项。在setEditorData()方法中,我们设置了QComboBox的当前选中选项为数据模型中的值。在setModelData()方法中,我们将用户选择的选项保存回数据模型。

你可以根据实际需求自定义QComboBox的选项列表,并根据需要进行修改和扩展。这样,你就可以在表格/列表视图的一列中使用QComboBox来实现动态填充。

关于PyQt的更多信息和使用方法,你可以参考腾讯云的PyQt产品文档:PyQt产品介绍

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Xcelsius(水晶易表)系列8——动态选择器高级用法

    今天继续跟大家分享关于水晶易表的动态选择器高级用法。 该案例所用到的函数和选择器工具还是我们之前用到的基本选择工具——单选按钮,组合框。 用到的思想与昨天讲到的思想基本一致,不过这里会有而迂回,你可以了通过对比参照,对excel中的动态交互函数与思想有更为深入的理解。 昨天使用的查询关键字是我用的&文本合并函数直接将年份、产品、地区名称链接在一起作为最终的查询字段,这里我会将三个字段(年份、产品、地区名称)分别编码,然后再利用&文本合并函数进行编码合并进而作为查询字段。 该篇用到的函数:&文本合并函数、V

    06

    MFC应用程序——标签控件_IP控件_时间控件_List Control控件_Tree Control控件_命令按钮_列表框_组合框_图片_滚动控件「建议收藏」

    【Tab Control 标签控件】 标签控件也比较常见。它可以把多个页面集成到一个窗口中, 每个页面对应一个标签,用户点击某个标签时,它对应的页 面就会显示。 使用标签控件我们可以同时加载多个有关联的页面,用 户只需点击标签即可实现页面切换,方便灵活的进行操作。 每个标签除了可以显示标签文本,还可以显示图标。 标签控件相当于是一个页面的容器,可以容纳多个对话 框,而且一般也只容纳对话框,所以我们不能直接在标签控 件上添加其他控件,必须先将其他控件放到对话框中,再将 对话框添加到标签控件中。最终我们点击标签切换页面时, 切换的不是控件的组合,而是对话框。

    01

    Vcl控件详解_c++控件

    大家好,又见面了,我是你们的朋友全栈君。 TTabControl 属性  DisplayRect:只定该控件客户区的一个矩形 HotTrack:设置当鼠标经过页标签时,它的字是否有变化。如果为True,是字会变成蓝色 Images:为每个页标签添加一个图片 MultiLine:如果总页标签的长度大于该控件的宽度时,是否允许多行显示 MultiSelect:是否允许多选页标签。该属性只有当Style为tsFlatButtons或tsButtons时才有效 OwnerDraw:是否允许自己绘画该控件 RaggedRight:指定是否允许标签页伸展到控制宽度 ScrollOpposite:该属性设置将会使MultiLine设为True。当标签页的行数大于1时,当单击其它页时,在它下面的页会自动翻动该控件的底部 Style:设置该控件的样式,大家一试就会知道 TabHeight:设置页标签的高度 TabIndex:反映当前标签页的索引号。该号从0开始 TabPosition:选择页标签的位置,分上,下,左,右 Tabs:对每个页进行增,删,改 TabWidth:设置页标签的宽度

    01

    Excel表格中最经典的36个小技巧,全在这儿了

    技巧1、单元格内强制换行 技巧2、锁定标题行 技巧3、打印标题行 技巧4、查找重复值 技巧5、删除重复值 技巧6、快速输入对号√ 技巧7、万元显示 技巧8、隐藏0值 技巧9、隐藏单元格所有值。 技巧10、单元格中输入00001 技巧11、按月填充日期 技巧12、合并多个单元格内容 技巧13、防止重复录入 技巧14、公式转数值 技巧15、小数变整数 技巧16、快速插入多行 技巧17、两列互换 技巧18、批量设置求和公式 技巧19、同时查看一个excel文件的两个工作表。 技巧20:同时修改多个工作表 技巧21:恢复未保存文件 技巧22、给excel文件添加打开密码 技巧23、快速关闭所有excel文件 技巧24、制作下拉菜单 技巧25、二级联动下拉 技巧27、删除空白行 技巧28、表格只能填写不能修改 技巧29、文字跨列居中显示 技巧30、批注添加图片 技巧31、批量隐藏和显示批注 技巧32、解决数字不能求和 技巧33、隔行插入空行 技巧34、快速调整最适合列宽 技巧35、快速复制公式 技巧36、合并单元格筛选

    02
    领券