【PyQt5 学习记录】011:使用 QListWidet 创建列表
[command]:<>(项目名称 : PyQt5)
[command]:<>(文件名称 : QListWidget.md)
[command]:<>(创建日期 : 2018 年 11 月 07 日)
[command]:<>(创建时间 : 00:41)
使用 QListWidet 创建列表
作者: 八月未见 博客: https://www.cnblogs.com/jmtm/
创建列表:
list_widget = QListWidget()
插入项目:
直接添加文字:
# 在末尾添加:
list_widget.addItem("Item")
items = ["Item - 1", "Item - 2"]
list_widget.addItems(items)
# 在指定行添加:
list_widget.insertItem(0, "Item")
items = ["Item - 1", "Item - 2"]
# 从第 1 行开始添加:
list_widget.insertItems(1, items)
举个栗子:
# 创建列表:
list_widget = QListWidget()
item_list = []
for i in range(20):
item_list.append("Item - " + str(i))
# 向列表添加项目:
list_widget.addItems(item_list)
效果如下:\

添加 item :
使用 QtWidgets.QListWidgetItem 创建项目
# 创建一个 item :
item = QListWidgetItem()
item.setIcon(QIcon("programme.png"))
item.setText("Item")
list_widget.addItem(item)
将项目添加到列表:
# 直接添加:
QListWidgetItem(QIcon("icon.png"), "Item", list_widget)
list_widget.addItem(item)
list_widget.insertItem(0, item)
栗子来了:
QListWidgetItem(QIcon("laugh.png"), "Item - 1", list_widget)
item = QListWidgetItem()
item.setIcon(QIcon("programme.png"))
item.setText("Item - 2")
list_widget.insertItem(0, item)
效果如图: \

编辑项目:
当前选项:
设置当前选项:
# 通过项目来设置当前选项:
list_widget.setCurrentItem(item)
# 通过行来设置当前选项:
list_widget.setCurrentRow(3)
获取当前选项:
# 获取当前选项:
current_item = list_widget.currentItem()
# 获取当前行:
current_row = list_widget.currentRow()
编辑选项:
# 开始编辑:
list_widget.openPersistentEditor(current_item)
# 结束编辑:
list_widget.closePersistentEditor(current_item)
删除选项:
# 删除第四行:
list_widget.takeItem(4)
# 移除选项上的其他组件:
# 注意:这不会删除选项,仅仅移除选项上的其他组件(如:Label、LineEdit、等)。
list_widget.removeItemWidget(current_item)
# 移除所有选项:
# 注意:这会让列表变成一片空白。
list_widget.clear()
选项数量:
list_widget.count()
在选项上显示组件:
# 如果你这么做了将会无法删除此选项:
list_widget.setItemWidget(item, QLabel("这是一个 Label !"))
查找选项:
# 在所有选项中查找有字符 4 的选项,并返回数组:
list_widget.findItems("4", Qt.MatchContains)
# 通过行找到选项:
# 注意:第一行是 0 。
list_widget.item(3)
隐藏选项:
list_widget.setRowHidden(2, True)
参考资料:QListWidget — Qt for Python (Technology Preview)
【PyQt5 学习记录】011:使用 QListWidet 创建列表的更多相关文章
- 【PyQt5 学习记录】009:批量创建组件并查找
这里需要在创建组件时使用 setObjectName() 为其添加 objectName 属性,再通过 findChild() 或者 findChildren() 函数来查找. 举个栗子,批量创建10 ...
- ROS学习记录(一)————创建简单的机器人模型smartcar
这是我在古月居上找的(http://www.guyuehome.com/243),但直接运行的话,没办法跑起来,我也是查了好多博客和日志,才实现最后的功能的,所以,记录下来,以备后用吧,也欢迎其他和我 ...
- 【PyQt5 学习记录】001:第一个界面
PyQt5 的安装很简单: pip3 install PyQt5 然后就是写一个最简单的界面试试手: import sys from PyQt5.QtWidgets import QApplicati ...
- ROS学习记录(三)————创建一个简单的发布节点和订阅节点
暑假在家有些懈怠,不,非常懈怠- -||!良心已经发痛了,想快些补回原来的进度,但忽然发现,中断了一段时间再重新去学习,有的地方连最基本的符号都忘记了 ,这次特意弄个最最基础的,恢复一下,以前的进度. ...
- 【PyQt5 学习记录】010:QSplitter
import sys from PyQt5.QtWidgets import (QApplication, QWidget, QSplitter, QTextEdit, QPushButton, QL ...
- 【PyQt5 学习记录】006:重写窗口事件及QMessageBox
#!/usr/bin/env python import sys from PyQt5.QtWidgets import (QApplication, QMainWindow, QMessageBox ...
- 【PyQt5 学习记录】005:QMainWindow 及状态栏、菜单栏和工具栏
#!/usr/bin/env python import sys from PyQt5.QtWidgets import (QApplication, QMainWindow, QWidget, QA ...
- 【PyQt5 学习记录】004:简单QThread笔记
在文本编辑框中每隔几秒添加一行文本,代码如下: #!/usr/bin/python3 # -*- coding:utf-8 -*- import sys from PyQt5.QtWidgets im ...
- 个人学习记录-Cpp基础-成员初始化列表
Translator Translator 参考链接: https://blog.csdn.net/XIONGXING_xx/article/details/115553291http ...
随机推荐
- 微信小程序redirect 到tab不刷新
// 更新2018/11/20:现在小程序的页面栈长度为10 更正 2018/11/20: 经过一段时间的实践,我发现以前方法存在很多问题,比如 getCurrentPages 方法并不在官方的 AP ...
- ios实现fastlane自动化打包
终于抽出时间来学习自动化打包了,app在测试阶段一天总会经历好几次的打包,每次打包真是身心疲惫,刚打完的包说不定就被测试妹子反应还要微调什么地方,我就真的有气没法出,打一次包怎么也得浪费十几分钟,还不 ...
- 《Head First 设计模式》读书笔记
目录 <Head First 设计模式>读书笔记 创建模式 结构模式 行为模式 用思维导图记录的读书笔记. <Head First 设计模式>读书笔记 模式的分类遵循<设 ...
- Odoo9.0模块开发全流程
构建Odoo模块 模块组成 业务对象 业务对象声明为Python类, 由Odoo自己主动加载. 数据文件 XML或CSV文件格式, 在当中声明了元数据(视图或工作流).配置数据(模块參数).演示数据等 ...
- vue、react、angular三大框架对比 && 与jQuery的对比
前端当前最火的三大框架当属vue.react以及angular了. 但是在做项目的时候,我们怎么去选择呢? 这里做一个比较,希望大家可以有一个比较清晰的认识. vue与react vue和react ...
- MySQl中的\g和\G
1. \g 在MySQL的sql语句后加上\g,效果等同于加上定界符,一般默认的定界符是分号; 2. \G 在MySQL的sql语句后加上\G,表示将查询结果进行按列打印,可以使每个字段打印到单独的行 ...
- 手淘适配-flexible
目标 拿一个双11的Mobile页面来做案例,比如你实现一个类似下图的一个H5页面: 目标很清晰,就是做一个这样的H5页面. 痛点 虽然H5的页面与PC的Web页面相比简单了不少,但让我们头痛的事情是 ...
- Maven-pom.xml文件报错 Plugin execution not covered by lifecycle configuration
问题: Eclipse中新导入的项目pom.xml文件报错: Plugin execution not covered by lifecycle configuration: org.jacoco:j ...
- 【C#小知识】C#中一些易混淆概念总结(五)---------继承 分类: C# 2014-02-06 22:05 1106人阅读 评论(0) 收藏
目录: [C#小知识]C#中一些易混淆概念总结--------数据类型存储位置,方法调用,out和ref参数的使用 [C#小知识]C#中一些易混淆概念总结(二)--------构造函数,this关键字 ...
- 【jQuery源码】工具函数
//扩展工具函数 jQuery.extend({ // Unique for each copy of jQuery on the page expando: "jQuery" + ...