当前位置: 首页 > news >正文

在PySide6/PyQt6的开发框架中,增加对表格多种格式录入的处理,以及主从表的数据显示和保存操作。

ySide6/PyQt6的开发框架主界面支持多文档管理,可包括菜单栏、工具栏、内容区和状态栏等,内容区以选项卡方式展示多个窗口,如下所示。

image

常规的编辑界面如用户界面,双击列表弹出展示,如下所示。

image

主从表展示界面如下所示。

image

主从表直接编辑界面,在弹出对话框中进行编辑主表信息和明细记录,明细记录通过表格方式直接录入,方便各种类型的数据录入处理。

1、在PySide6/PyQt6的开发框架中表格的数据录入

我们先来看看测试案例,查看下表格中多种格式录入的效果

image

视频效果如下所示

如我们在产品报价单中进行主从表编辑数据的时候,界面如下所示,其中产品信息通过弹出自定义产品列表进行选择。

image

其他如产品类型、产品规格、产品型号、标准单位、产品尺寸等通过绑定系统字典类型,作为下拉列表的数据源。

image

上面就是实际的报价单的界面录入,可以通过自定义的对话框选择,也可以直接录入文本,还可以通过绑定字典类型获得下拉列表选择等处理操作。

2、表格数据直接录入的委托类处理

在PySide6/PyQt6中,对于 QTableView 的定制化输入,是通过继承 QStyledItemDelegate 来实现定制化的表格单元格输入或者显示的。如我们自定义类如下所示。

class CustomDelegate(QStyledItemDelegate):

我们让它支持的类型包括:

- text: 普通文本 (QLineEdit)

- int: 整数 (QSpinBox)

- double: 浮点数 (QDoubleSpinBox)

- date: 日期 (QDateEdit)

- combo: 下拉选择 (QComboBox)

- check: 复选框 (直接显示)

- radio: 单选按钮组 (QRadioButton)

- slider: 滑动条 (QSlider)

- multiline: 多行文本 (QTextEdit)

- password: 密码文本 (QLineEdit)

- percent: 百分比 (QDoubleSpinBox)

- currency: 货币 (QDoubleSpinBox)

- time: 时间 (QTimeEdit)

- datetime: 日期时间 (QDateTimeEdit)

- color: 颜色选择 (QPushButton)

- icon: 图标选择 (QPushButton)

- bitmap: 位图选择 (QPushButton)

- custom: 自定义不可编辑控件,同时触发 customTriggered 信号,传出单元格索引和字段名称

最终它的配置示例如下代码所示。

config = {

"name": {"type": "text"},

"age": {"type": "int", "min": 0, "max": 120},

"score": {"type": "double", "min": 0, "max": 1000, "decimals": 3, "step": 0.01},

"birthday": {"type": "date", "format": "yyyy-MM-dd"},

"tag": {"type": "combo", "items": ["选项A", "选项B", "选项C"]},

"married": {"type": "check", "true": "是", "false": "否"},

"gender": {"type": "radio", "items": ["男", "女", "未知"], "width": 180},

"score_2": {"type": "slider", "min": 0, "max": 100, "step": 1},

"description": {"type": "multiline"},

"password": {"type": "password"},

"percent": {"type": "percent", "min": 0, "max": 100, "decimals": 2, "step": 0.1},

"currency": {"type": "currency", "min": 0, "max": 1000000, "decimals": 2, "step": 0.1},

"time": {"type": "time", "format": "HH:mm:ss"},

"datetime": {"type": "datetime", "format": "yyyy-MM-dd HH:mm:ss"},

"color": {"type": "color", "format": "color"},

"icon": {"type": "icon", "default": "SP_ArrowDown"},

"bitmap": {"type": "bitmap", "default": "bitmap.png"},

}

view = QTableView()

view.setModel(model)

delegate = CustomDelegate(config, view)

view.setItemDelegate(delegate)

同时我们为了支持自定义的列表对话框选择,那么我们通过触发信号来获得对应的事件处理即可,如下所示。

#自定义单元格编辑事件

self.delegate.customTriggered.connect(self.on_custom_triggered)

def on_custom_triggered(self, index: QModelIndex, field_name: str):

"""自定义单元格编辑事件"""

# print(f"on_custom_triggered: index={index}, field_name={field_name}")

if field_name == "productno":

# 弹出选择产品对话框

dlg = FrmProductSelect(self)

if dlg.exec() == QDialog.DialogCode.Accepted:

info = dlg.select_product

if info is not None:

# print(f"选择的产品信息:{info}")

row = index.row()

self.sub_table_model.SetValueByKey(row, "productno", info.productno)

# #同步更新产品名称/条形码/规格/型号/单位/颜色/尺寸等

self.sub_table_model.SetValueByKey(row, "productname", info.productname)

....

# 同步更新数量

....

# 同步更新金额小结

....

dlg.deleteLater()

通过对自定义委托类中的 信号对象 customTriggered 进行监听,我们就可以获得用户触发选择某个单元格的事件,并可以通过弹出自定义对话框获取列表选择,并把数据写回到对应单元格中即可。

而对于指定系统字典类型,作为下拉列表的操作,我们只需要设置字段类型为combo或者radio,并动态设置字典类型绑定即可。

#表格单元格的编辑控件配置, 动态指定字典

config = {

"orderno": {"type": "text"},

"quantity": {"type": "int", "min": 0, "max": 1000},

"saleprice": {"type": "double", "min": 0, "decimals": 3, "step": 0.01},

"subamout": {"type": "double", "min": 0, "decimals": 3, "step": 0.01},

"expiredate": {"type": "date", "format": "yyyy-MM-dd"},

"note": {"type": "multiline"},

"productno": {"type": "custom"},

"producttype": {"type": "combo"},

"model": {"type": "combo"},

"specification": {"type": "combo"},

"unit": {"type": "combo"},

"color": {"type": "combo"},

"productsize": {"type": "radio"},

http://www.cnnetsun.cn/news/174582.html

相关文章:

  • 通过命令模拟pod创建
  • 同步机无感 STM32 低成本 MD500E 永磁同步控制方案大揭秘
  • 小宝玩具 【通达信、源码 、主图、附图】
  • 使用 Github Pages 和 Hexo
  • 审稿 一区期刊注意事项: journal offers the option to connec;please note, reviewers are not expected 是什么意思
  • 线性代数:多维世界的变形工具箱
  • 力扣题目142. 环形链表 II​的解法分享,附图解
  • MATLAB电力系统继电保护之自动重合闸
  • 10 个AI写作工具,助你轻松搞定继续教育论文!
  • 【开题答辩全过程】以 基于Vue的茶道知识科普网站的设计与实现为例,包含答辩的问题和答案
  • 主动配电网两阶段鲁棒恢复:Matlab 代码探索之旅
  • ICG-20660L加速度+陀螺仪六轴IMU传感器原理图设计,已量产(加速度传感器)
  • 百度AI架构师亲授:Agentic智能体在医疗领域的落地(附诊断案例)
  • 软件工程期末高频易错点深度剖析:避开这些坑,你就赢了!
  • 打破 AI 创作枷锁!虎贲等考 AI 双效赋能,让学术原创不设限
  • AI 赋能学术演示!虎贲等考 AI PPT,让科研汇报告别 “无效努力”
  • 听完这场AI产品大会,我觉得如果不赚钱,所谓的提效真的毫无意义。
  • PWN手的成长之路-19-int_overflow
  • Thinkphp和Laravel党员素质能力提升管理系统vue
  • 【权威对比】Open-AutoGLM与Parasoft SOAtest集成能力评测:数据背后的真相
  • eDiary电子日记本(记录生活点滴)
  • Thinkphp和Laravel+vue好未来团购网系统vue
  • Open-AutoGLM vs SoapUI:谁才是自动化测试协同的终极利器?
  • Android ---【经验篇】项目上线前工序:部署 SpringBoot 项目(二)
  • 还在盲目集成测试工具?Open-AutoGLM与SOAtest的6个致命区别你必须知道
  • 基于springboot+vue的Web的出租车拼车系统(源码+lw+部署文档+讲解等)
  • 基于springboot+vue的Vue和SpringBoot的城市环保行政执法系统(源码+lw+部署文档+讲解等)
  • 基于VUE的教师培训在线管理平台[VUE]-计算机毕业设计源码+LW文档
  • 【自动化测试平台选型避坑指南】:从Open-AutoGLM到Tosca的7项适配指标实测对比
  • Open-AutoGLM vs JMeter:性能测试如何选择?3大维度全面解析