PyQt4 ShowHMDB show sqlite3 with QTableWidget summary
PyQt4 ShowHMDB show sqlite3 with QTableWidget summary
Source Code: https://github.com/zengjfgit/Python
1. QDialog固定窗口大小:
self.setFixedHeight(self.height())
self.setFixedWidth(self.width())
2. QDialog设置窗口无问号:
self.setWindowFlags(self.windowFlags() & ~Qt.WindowContextHelpButtonHint)
3. QFileDialog获取数据库文件路径:
path = QFileDialog.getOpenFileName( self, "Select Files", ".", "*.db" )
if ( QFileInfo(path).completeSuffix().compare("db") == 0 ) :
self.ui.dbPath.setText(path)
elif ( path.compare("") == 0 ) :
self.ui.dbPath.setText("")
else :
QMessageBox.about(self, "Mesg","Please open DB file with .db suffix. ")
4. ShowHMDB主要使用了QTableWidget进行Sqlite数据数据显示。
5. 设置QTableWidget列宽的方法,这里采用硬编码(罪过):
self.ui.dbData.setColumnWidth(0, 83)
6. 处理按钮信号,槽函数一定不要打括号:
self.ui.getPath.clicked.connect(self.getHMDBPath)
7. 清除QTableWidget中数据:
self.ui.dbData.clearContents()
self.ui.dbData.setRowCount(0)
8. QTableWidget中的列宽是随时设置的,并不是一成不变的,这样可以解决无数据的时候
列宽和有数据时列宽不一致的问题:
9. sqlite3库并不含hasnext()这样的方法,至少目前未找到更好的方法,所以这里采用这种
方式获取数据:
current = cursor.fetchone()
while ( current ) :
......
current = cursor.fetchone()
10. 获取数据库中具有record记录总数:
cursor.execute('select count(*) from HardwareManager')
hmDBRecord = cursor.fetchone()[0]
11. 在往QTableWidget中加入Item之前,一定要row的计数器,否则插入的Item显示不出来,
这也是为什么需要去先查询数据库中总的record的总数的原因:
self.ui.dbData.setRowCount(hmDBRecord)
12. QTableWidgetItem传入的是QString,如果直接给current[0],代表的数字对应的字符
所以这里需要QString.number(current[0])进行转换:
id = QTableWidgetItem(QString.number(current[0]))
13. QTableWidgetItem内部文字对其方式设置如下:
id.setTextAlignment(Qt.AlignHCenter | Qt.AlignVCenter)
PyQt4 ShowHMDB show sqlite3 with QTableWidget summary的更多相关文章
- PyQt4 里的表格部件的使用方法: QTableWidget
PyQt4 里的表格部件的使用方法: QTableWidget QT下QTableWidget使用方法小结 - - 博客频道 - CSDN.NET http://blog.csdn.net/jingz ...
- 【转载】pyqt QTableWidget的使用
转载地址: http://blog.sina.com.cn/s/blog_9b78c91101019sgi.html QTableWidget是QT程序中常用的显示数据表格的空间,很类似于VC.C#中 ...
- QTableWidget查找指定项(由github处学习到)
from PyQt4 import QtGui, QtCore class Window(QtGui.QWidget): def __init__(self, rows, columns): QtGu ...
- qt model/view 架构基础介绍之QTableWidget
# -*- coding: utf-8 -*- # python:2.x #说明:QTreeWidget用于展示树型结构,也就是层次结构同前面说的 QListWidget 类似,这个类需要同另外一个辅 ...
- pyqt QTableWidget例子学习(重点)
# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' from PyQt4.QtGui import * from PyQ ...
- 数据库 --> sqlite3之api使用
创建 if [ ! -d /opt/dbspace ] then mkdir /opt/dbspace fi if [ -f /opt/dbspace/.memo.db ] then rm /opt/ ...
- PyQt4 HardwareManager
# PyQt4 HardwareManager # 声明: # 本软件主要是由于朋友说想要一个产品缺陷记录软件,主要用于记录产品缺陷, # 通过产品序列号进行插入.查询,本来想用VC++ 6.0做,但 ...
- PyQt4 QListWidget 使用教程
转自:http://blog.csdn.net/seeground/article/details/49177387?locationNum=3&fps=1 listWidget = QLis ...
- C 扩展库 - sqlite3 API
sqlite3 API Summary sqlite3 The database connection object. Created by sqlite3_open() and destroyed ...
随机推荐
- jdk eclipse SDK下载安装及配置教程
原文地址https://blog.csdn.net/dr_neo/article/details/49870587 最新鲜最详细的Android SDK下载安装及配置教程 最近Neo突发神经,想要将学 ...
- java中string.trim()函数的作用
trim /[trɪm] / 英文意思:整理,修理,修剪,整齐的 trim()的作用:去掉字符串首尾的空格. public static void main(String arg[]){ Strin ...
- (转)WPF学习资源整理
由于笔者正在学习WPF,所以整理出网络中部分WPF的学习资源,希望对同样在学习WPF的朋友们有所帮助. 首推刘铁猛的<深入浅出WPF>系列博文 1.深入浅出WPF(1)——什么是WPFht ...
- LA 4287 有相图的强连通分量
大白书P322 , 一个有向图在添加至少的边使得整个图变成强连通图, 是计算整个图有a个点没有 入度, b 个点没有出度, 答案为 max(a,b) ; 至今不知所云.(求教) #include &l ...
- 工具推荐. 在线unix, 在线python/perl脚本测试环境
在线python, perl, javascript, Lisp, Ruby等 http://melpon.org/wandbox/ 正则表达式在线测试工具 http://tools.jb51.ne ...
- 三.野指针和free
在C语言项目中,经常会遇到需要程序员手动分配内存的地方.这样做能够节省大量的内存空间,也让程序更加灵活.只要你有一定的基础,那么肯定用过 malloc 或者 ralloc和free的组合.这个组合使用 ...
- Python3.x:bs4解析html基础用法
Python3.x:bs4解析html基础用法 代码: import urllib.request from bs4 import BeautifulSoup import re url = r'ht ...
- 20145105 《Java程序设计》第1周学习总结
20145105 <Java程序设计>第1周学习总结 教材学习内容总结 学习了教材的第一章后,我初步了解了Java的发展历程,以及什么是JCP,JSR,JVM.JCP是一个开放性国际组织, ...
- Java静态内存与动态内存分配的解析
1. 静态内存 静态内存是指在程序开始运行时由编译器分配的内存,它的分配是在程序开始编译时完成的,不占用CPU资源. 程序中的各种变量,在编译时系统已经为其分配了所需的内存空间,当该变量在作用域内使用 ...
- Java网络编程学习A轮_04_TCP连接异常
参考资料: https://huoding.com/2016/01/19/488 示例代码: https://github.com/gordonklg/study,socket module A. C ...