在pyqt5中如何实现grid(创建二维表格)功能

本文介绍了使用PyQt5实现表格功能,包括创建基本表格、单元格内容设置、排序功能(如QTableView的列标题排序)以及利用QtDesigner工具生成代码。还探讨了界面实现策略和业务逻辑分离的最佳实践。

前言:由于本人是先学会使用wxpython实现python开发上位机界面程序,再转到pyqt5开发python上位机程序的,所以对pyqt5一些控件功能的了解可能是基于wxpython有相似功能的控件,现在想使用pyqt5实现生成表格单元数据。

参考文章:随笔分类 - PyQt入门教程(详细介绍pyqt常用技巧的文章合集,建议收藏!!!)

https://pythonspot.com/pyqt5-table/

PyQt5中对单元格进行排序
PyQt5 中的 QTableView 排序
PyQt5 TableView 点击某一列标题进行排序

重点:界面实现建议还是desiger设计工具实现,同时使用业务和逻辑相分离的方式编写程序

如何基于代码创建表格

在这里插入图片描述
在这里插入图片描述

地址:https://pythonspot.com/pyqt5-table/,提供的创建表格Table的方法:

import sys
from PyQt5.QtWidgets import QMainWindow, QApplication, QWidget, QAction, QTableWidget,QTableWidgetItem,QVBoxLayout
from PyQt5.QtGui import QIcon
from PyQt5.QtCore import pyqtSlot

class App(QWidget):

    def __init__(self):
        super().__init__()
        self.title = 'PyQt5 table - pythonspot.com'
        self.left = 0
        self.top = 0
        self.width = 300
        self.height = 200
        self.initUI()
        
    def initUI(self):
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)
        
        self.createTable()

        # Add box layout, add table to box layout and add box layout to widget
        self.layout = QVBoxLayout()
        self.layout.addWidget(self.tableWidget) 
        self.setLayout(self.layout) 

        # Show widget
        self.show()

    def createTable(self):
       # Create table
        self.tableWidget = QTableWidget()
        self.tableWidget.setRowCount(4)
        self.tableWidget.setColumnCount(2)
        self.tableWidget.setItem(0,0, QTableWidgetItem("Cell (1,1)"))
        self.tableWidget.setItem(0,1, QTableWidgetItem("Cell (1,2)"))
        self.tableWidget.setItem(1,0, QTableWidgetItem("Cell (2,1)"))
        self.tableWidget.setItem(1,1, QTableWidgetItem("Cell (2,2)"))
        self.tableWidget.setItem(2,0, QTableWidgetItem("Cell (3,1)"))
        self.tableWidget.setItem(2,1, QTableWidgetItem("Cell (3,2)"))
        self.tableWidget.setItem(3,0, QTableWidgetItem("Cell (4,1)"))
        self.tableWidget.setItem(3,1, QTableWidgetItem("Cell (4,2)"))
        self.tableWidget.move(0,0)

        # table selection change
        self.tableWidget.doubleClicked.connect(self.on_click)

    @pyqtSlot()
    def on_click(self):
        print("\n")
        for currentQTableWidgetItem in self.tableWidget
### PyQt5 控件自适应窗口大小的实现PyQt5 中,为了使控件能够随窗口大小的变化而自动调整其尺寸和位置,可以利用 **布局管理器** 来完成这一功能。通过合理设置布局管理器,可以使控件按照预定义的方式重新排列并缩放。 #### 使用布局管理器的方法 PyQt 提供了几种常见的布局方式来帮助开发者轻松实现控件的动态调整: 1. **水平布局 (QHBoxLayout)** 将多个控件按水平方向依次排列。当窗口宽度发生变化时,这些控件会随之拉伸或压缩[^1]。 2. **垂直布局 (QVBoxLayout)** 类似于水平布局,但它是将控件沿竖直方向堆叠放置。如果选择了这种布局,则所有控件会在高度变化时相应地调整间距或者比例。 3. **网格布局 (QGridLayout)** 这是一种更复杂的布局形式,允许在一个二维表格结构中定位各个子部件的位置以及它们占据的空间数量。它非常适合用于表单输入或其他需要精确控制相对位置的应用场景[^2]。 4. **表单布局 (QFormLayout)** 特别适合用来构建带有标签字段成对显示的数据录入区域,在这里每一行通常由一个描述性的文字说明加对应的编辑框组成。 以下是具体代码示例展示如何应用上述提到的各种类型的布局到实际项目当中去: ```python from PyQt5.QtWidgets import QApplication, QWidget, QPushButton, QVBoxLayout, QHBoxLayout, QGridLayout, QFormLayout class Example(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): okButton = QPushButton("OK") cancelButton = QPushButton("Cancel") hbox = QHBoxLayout() hbox.addStretch(1) hbox.addWidget(okButton) hbox.addWidget(cancelButton) vbox = QVBoxLayout() vbox.addStretch(1) vbox.addLayout(hbox) grid = QGridLayout() names = ['Cls', 'Bck', '', 'Close', '7', '8', '9', '/', '4', '5', '6', '*', '1', '2', '3', '-', '0', '.', '=', '+'] positions = [(i,j) for i in range(5) for j in range(4)] for position, name in zip(positions, names): if name == '': continue button = QPushButton(name) grid.addWidget(button, *position) form_layout = QFormLayout() form_layout.addRow("Name:", QLineEdit()) form_layout.addRow("Age:", QLineEdit()) main_layout = QVBoxLayout() # 创建主布局容器 main_layout.addLayout(grid) # 添加网格布局至主布局 main_layout.addLayout(form_layout) # 添加表单布局至主布局 main_layout.addLayout(vbox) # 添加垂直按钮组布局至主布局 self.setLayout(main_layout) # 设置最终的整体布局给当前窗口实例对象 app = QApplication([]) ex = Example() ex.show() app.exec_() ``` 以上程序片段展示了四种不同风格的布局组合在一起的效果。其中 `main_layout` 是整个界面的基础框架;内部嵌套了其他三种特定用途的小型局部布局单元——分别是按键矩阵区(`grid`)、个人信息填写部分(`form_layout`)还有底部操作选项栏(`vbox`)。这样做的好处在于可以让每个独立的功能模块都拥有自己专属的表现形态的同时又能很好地融入整体协调一致的设计之中. 另外需要注意的是,除了正确选用合适的布局类之外,还应该考虑适当运用诸如 `addStretch()` 方法之类的辅助工具进一步优化视觉效果,使得界面看起来更加美观大方且用户体验友好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

草莓仙生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值