from decimal import *

from PyQt4.QtGui import *

from PyQt4.Qt import *

from PyQt4.QtCore import *

import sys

class Example(QWidget):

def __init__(self,args=None):

super(Example, self).__init__(args)

list_data=[1,2,3,4]

lm=MyListMode(list_data,self)

self.lv=QListView()

self.lv.setToolTip('listview')

self.lv.setModel(lm)

self.la= MyItemMode()

self.lv.clicked.connect(self.indexMove)

layot=QVBoxLayout()

layot.addWidget(self.lv)

self.setLayout(layot)

def indexMove(self,text):

print u'你选择的是{0}'.format(text.row())

print dir(text)

if text.row()==0:#obj.row()指定的项

self.lv.setModel(self.la)

class MyListMode(QAbstractListModel):

def __init__(self,datain,parnet=None,*args):

"""数据:一列表中的每个项目是一个行"""

super(MyListMode,self).__init__(parnet,*args)

self.listdata=datain

#这2个方法是规定好的

def rowCount(self,parent=QModelIndex()):

return len(self.listdata)

def data(self,index,row):#isValid()是否有效的

if index.isValid() and row==Qt.DisplayRole:#关键数据以文本的形式呈现

return QVariant(self.listdata[index.row()])#QVariant类就像一个最常见的Qt联盟数据类型

else:

return QVariant()

#QStandardItemModel类提供了一个通用的模型来存储自定义数据

class MyItemMode(QStandardItemModel):

def __init__(self,parnet=None):

super(QStandardItemModel,self).__init__(parnet)

for i in xrange(10):

item=QStandardItem('items%d'%i)

item.setFlags(Qt.ItemIsUserCheckable|Qt.ItemIsEnabled)#ItemIsUserCheckable接受与不接受

#ItemIsEnabled用于交互

item.setData(QVariant(Qt.Checked),Qt.CheckStateRole)#Checked检查是否选中

#CheckStateRole检查是否选择的状态

self.appendRow(item)#附加一行包含项目。 如果有必要,列数增加的大小项目。

def paintStart(self):

l=[]

for i in xrange(self.rowCount()):

l.append(self.item(i).ckeckState())

print l

#self.setCentralWidget(view)中央位置

app =QApplication(sys.argv)

x = Example()

x.show()

sys.exit(app.exec_())

如图:

学习内容都从文档和谷歌搜索,有兴趣的朋友可以学习下

pyqt listview基础学习01的更多相关文章

  1. T-SQL 基础学习 01

    --新建数据库 create database Studentdb go --使用数据库 use Studentdb go --新建表 create table Username ( StudentN ...

  2. XML基础学习01

    XML学习 1:XML:可扩展的标识语言,是一种描述结构数据的格式,简化了网络中数据交换和表示,使得代码,数据和表示分离,并作为数据交换的标准格式,被称为智能数据文档. 2:当我们不使用数据库来存储数 ...

  3. java基础学习01

    学习主意:边看视频,边编写代码,学习成果体现在代码

  4. [AngularJS学习笔记] 基础学习01

    2016-06-06开始学习AngularJS AngularJS是会extend HTML的 ng-directives 先学习了四个 ng-app:定义AngularJS Application的 ...

  5. pyqt treeview基础学习

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' from PyQt4.QtGui import  * from Py ...

  6. c语言基础学习01

    =============================================================================每一种语言都有其独特的语法规则与语言定义. 指 ...

  7. Python基础学习01

    1.编译型解释型语言区别: 编译型:一次性将全部代码编译成二进制文件,代表c,c++ 优点:执行效率高 缺点:开发速度慢,不能跨平台 解释型:当程序运行时,从上至下一行一行执行,解释成二进制去执行 优 ...

  8. 18-09-21 numpy 的基础学习01

    # 1关于numpy 的学习import numpy as np # 一 如何创建数组****# 1 有规律的一维数据的创建======# 1 range() 和arange() 区别 貌似没有区别l ...

  9. spring基础学习01

    spring基础 Spring是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用 IOC控制反转 把创建对象和维护对象之间的关系权利 ...

随机推荐

  1. 基于Cordova5.0开发自己定义插件(android)

    1.开发插件java部分 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvenhmMjE2MjE2/font/5a6L5L2T/fontsize/400/fi ...

  2. openfire文件夹

    插件开发 学习制作第一个 openfire 插件 http://www.cnblogs.com/jying/p/3683409.html 跟我一步一步开发自己的Openfire插件 http://bl ...

  3. Hexo博客搭建图文教程

    准备 你需要准备好以下软件: Node.js环境 Git Windows 配置Node.js环境 下载Node.js安装文件: Windows Installer 32-bit Windows Ins ...

  4. git 学习笔记一

    1.git的 介绍 分布式和 集中式 集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟, ...

  5. CentOS6.6(单用户模式)重设root密码

    1.开机时手要快按任意键,因为默认时间5s 2.grub菜单,只有一个内核,没什么好上下选的,按e键.不过如果你升级了系统或安装了Xen虚拟化后,就会有多个显示了. 3.接下来显示如下,选择第二项,按 ...

  6. Fedora安装VirtualBox时出现错误Kernel driver not installed (rc=-1908)的解决办法

    新建虚拟机后启动时出现如下错误: Kernel driver not installed (rc=-1908) The VirtualBox Linux kernel driver (vboxdrv) ...

  7. .net 网站发布 Web.Config中的<compilation debug="true"/>

    Web.Config中的<compilation debug="true"/> <compilation debug="true"/> ...

  8. IP地址基础和子网规划之其一

    IP地址的介绍:在TCP/IP环境中,各种各样的终端.工作站能同服务器.其他工作站无缝连接,是因为每一网络节点都使用了全网范围内能够唯一标识节点的IP地址.每个网络有一个全网唯一的网络号,在该网络中各 ...

  9. sqlite编译

    1.下载代码:http://www.sqlite.org/download.html ,windows下下载sqlite-amalgamation-xxx.zip和sqlite-dll-win32-x ...

  10. jquery select三级联动

    需求:对地区进行选择,选择相应的省,就会出现相应范围的市,然后出现相应的范围的县区:如果县不存在,就不现实,自我要求是自己写个简单的插件,方便以后调用: 逻辑:1.通过div的类名来获取,其下的sel ...