# -*- coding: utf-8 -*-

# python:2.x

#QStringListModel

#QStringListModel 是最简单的模型类,具备向视图提供字符串数据的能力。

#QStringListModel 是一个可编辑的模型,可以为组件提供一系列字符串作为数据。

#看作是封装了 QStringList 的模型。QStringList 是一种很常用的数据类型,实际上

#是一个字符串列表(也就是 QList<QString>)。既然是列表,它也就是线性的数据结构,

#因此, QStringListModel 很多时候都会作为 QListView 或者 QComboBox 这种只有一列

#的视图组件的数据模型。

__author__ = 'Administrator'

from PyQt4.QtGui import  *

from PyQt4.Qt import *

from PyQt4 import QtGui, QtCore

from PyQt4.QtCore import *

import sys

class Painterd(QWidget):

def __init__(self):

super(Painterd,self).__init__()

self.setFixedSize(300,200)

self.vector()

def vector(self):

tablewidtet=QStringList()

tablewidtet.append('a')

tablewidtet.append('b')

tablewidtet.append('c')

tablewidtet.append('d')

self.model=QStringListModel(self)

self.listView=QListView(self)

self.model.setStringList(tablewidtet)

self.listView.setModel(self.model)

btnLayout=QHBoxLayout()

insertBtn=QPushButton('insert',self)

dels=QPushButton('delete',self)

showbto=QPushButton('show',self)

btnLayout.addWidget(insertBtn)

btnLayout.addWidget(dels)

btnLayout.addWidget(showbto)

mainlayout=QVBoxLayout(self)

mainlayout.addWidget(self.listView)

mainlayout.addLayout(btnLayout)

self.setLayout(mainlayout)

insertBtn.clicked.connect(self.inpits)

dels.clicked.connect(self.dels1)

showbto.clicked.connect(self.edits)

def edits(self):#直接按F2就可以编辑,不用自己实再实现编辑功能

row=self.listView.currentIndex().row()

index=self.model.index(row)

variant=self.model.data(index,Qt.DisplayRole)#获取当前选择项文本

text=variant.toString()

ok,text=QInputDialog.getText(self,u'输入',u'请输入内容?',QLineEdit.Normal,text)#要求用户输入数据

#解释这部分代码:

#首先插入空行,然后选中新插入的空行,设置新的

# 数据。这其实是一种冗余操作,因为 currentIndex()已经获取到当前行。

if ok:

row=self.listView.currentIndex().row()#获取 Q ListView 当前行的项

self.model.insertRows(row,1)

"""

QStringListModel 的

一个重载。参数  1  说明要插入  1  条数据。记得之前我们已经把  row  设置为当前行,因此,

这行语句实际上是在当前的  row  位置插入  count  行,这里的  count  为  1。由于我们没有添

加任何数据,实际效果是,我们在  row  位置插入了  1  个空行。然后我们使用  model  的

index()函数获取当前行的 QModelIndex 对象,利用 setData()函数把我们用 QInputDialog

接受的数据设置为当前行数据。接下来,我们使用 setCurrentIndex()函数,把当前行设为

新插入的一行,并调用 edit()函数,使这一行可以被编辑。

"""

index=self.model.index(row)#QModelIndex类是用于定位数据的数据模型:三个重要的数据:行索引、列索引以及该数据属于哪一个模型,调用其 row()函数获得行索引,该返回值是一个  int,也就是当前是第几行

#bool insertRows(int row, int count, const QModelIndex &parent = QModelIndex());

#count行插入到模型给定的row位置,新行的数据将会作为parent子元素,如果row是0,新行将被插入到parent所有数据之前,否则将在指定的位置数据之前,如果

#parent没有子元素,则会新插入一个单列数据,函数 插入返回成功True,否则False,

self.model.setData(index,text)

self.listView.setCurrentIndex(index)

def dels1(self):

self.model.removeRows(self.listView.currentIndex().row(),1)

def inpits(self):

ok,text=QInputDialog.getText(self,u'输入',u'请输入内容?',QLineEdit.Normal,'')

if ok:

row=self.listView.currentIndex().row()

self.model.insertRows(row,1)

index=self.model.index(row)

self.model.setData(index,text)

self.listView.setCurrentIndex(index)

def main():

app = QtGui.QApplication(sys.argv)

ex =Painterd()

ex.show()

sys.exit(app.exec_())

if __name__ == '__main__':

main()

如图:

#例子原地址:http://www.cnblogs.com/venow/archive/2012/10/17/2728299.html

qt model/view 架构自定义模型之QStringListModel的更多相关文章

  1. qt model/view 架构自定义模型之QFileSystemModel

    # -*- coding: utf-8 -*- # python:2.x #QFileSystemModel """ Qt  内置了两种模型:QStandardItemM ...

  2. qt model/view 架构基础介绍之QListWidget

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

  3. qt model/view 架构基础介绍之QTableWidget

    # -*- coding: utf-8 -*- # python:2.x #说明:QTreeWidget用于展示树型结构,也就是层次结构同前面说的 QListWidget 类似,这个类需要同另外一个辅 ...

  4. qt model/view 架构基础介绍之QTreeWidget

    # -*- coding: utf-8 -*- # python:2.x #说明:QTreeWidget用于展示树型结构,也就是层次结构同前面说的 QListWidget 类似,这个类需要同另外一个辅 ...

  5. 第15.22节 PyQt(Python+Qt)入门学习:Model/View架构详解

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.简介 在PyQt和Qt中,Model/View架构是图形界面开发时用于管理数据和界面展现方式的关 ...

  6. PyQt(Python+Qt)学习随笔:Model/View架构中的Model模型概念

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 Model/View架构中的Model模型Model与数据源通信,为体系结构中的其他组件提供数据接口 ...

  7. Qt 学习之路 2(41):model/view 架构

    Qt 学习之路 2(41):model/view 架构 豆子 2013年1月23日 Qt 学习之路 2 50条评论 有时,我们的系统需要显示大量数据,比如从数据库中读取数据,以自己的方式显示在自己的应 ...

  8. 第15.23节 PyQt(Python+Qt)入门学习:Model/View架构中QListView视图配套Model的开发使用

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 QListView理论上可以和所有QAbstractItemModel派生的类如QStri ...

  9. PyQt(Python+Qt)学习随笔:Model/View架构概述

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.引言 模型-视图-控制器(Model-View-Controller,简称MVC)是一种源于Sm ...

随机推荐

  1. cocos2d-x核心基础类

    Application 应用程序入口类 EGLView 绘图句柄 Director Node Layer Scene

  2. #爬虫必备,解析html文档----beautifulsoup的简单用法

    #出处:http://mp.weixin.qq.com/s?__biz=MjM5NzU0MzU0Nw==&mid=201820961&idx=2&sn=b729466f334d ...

  3. hcharts

    折线图 http://www.hcharts.cn/demo/index.php?p=10 饼状图 http://higrid.net/docs/highcharts_cn/#plotOptions- ...

  4. iOS 部分问题总结2 - 苹果审核篇

    iOS 部分问题总结(二) - 苹果审核篇 1. 记录下5.1新规后上传被拒的问题排查和解决过程. 几天前,最新一次的更新被拒了,提示Invaild Binary.好在苹果同时发来了说明邮件做了详细说 ...

  5. Android 按二次后退键退出应用程序

    前言          欢迎大家我分享和推荐好用的代码段~~ 声明          欢迎转载,但请保留文章原始出处:          CSDN:http://www.csdn.net        ...

  6. 自写图片遮罩层放大功能jquery插件源代码,photobox.js 1.0版,不兼容IE6

    阿嚏~~~ 话说本屌丝没啥开发插件的经验,可是天公不作美,公司须要让我自己开发个图片放大的插件 但公司老大的话,宛如吾皇之圣旨,微臣必当肝脑涂地,莫敢不从啊~~~ 于是乎,作为一个超级小白,本人仅仅能 ...

  7. Sass@规则

    @importSass 支持所有 CSS3 的 @ 规则, 以及一些 Sass 专属的规则,也被称为“指令(directives)”.Sass 扩展了 CSS 的 @import 规则,让它能够引入 ...

  8. FineUI页面布局

    使用布局的优势 相对于为控件设置固定的宽度和高度,布局的重要意义在于子控件可以根据父控件的尺寸自动设置自己的尺寸,在页面尺寸改变时同样有效.如果你在项目中遇到类似如下的需求,就需要考虑布局了: 面板填 ...

  9. linux oracle 设置随系统自动启动数据库实例和监听

    在root账户下修改/etc/oratab 文件: # vi /etc/oratab 找到orcl=/db/app/oracle/product/11.1.0/db_1 :N这一行 改为: orcl= ...

  10. cocos2dx-触摸事件

    //创建一个精灵 Sprite *spriteTest = Sprite::create("1.png"); spriteTest->setPosition(Point(,) ...