Pyqt5--解析json并将内容显示在tableWidget

2023-11-22 18:59

本文主要是介绍Pyqt5--解析json并将内容显示在tableWidget,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在开始写本博客的案例之前,梳理下功能点和知识点,方便查找和理解。

功能介绍:

1.生成json数据;

2.解析json数据并将内容显示在tableWidget中;

3.获取lineEdit中输入的内容,并将其显示在tableWidget中。

知识点梳理:

1.json

json是一种易于阅读和编写的数据交换格式。

json.dumps()函数是将字典转化为字符串------jsonStr = json.dumps(strData)

json.loads()函数是将字符串转化为字典--------res = json.loads(jsonStr)

2.Qt Designer界面设计--比较简单

控件,信号和槽的使用可以参考https://blog.csdn.net/maidu_xbd/article/details/85696510

3.tableWidget

self.ui.tableWidget.setColumnCount(5) # 设置表格的列数

self.ui.tableWidget.setRowCount(100) #设置表格的行数

mTitle = QTableWidgetItem(item['name']) #显示数据

mTitle.setTextAlignment(Qt.AlignCenter) # 设置文字显示居中

mTitle.setFlags(Qt.ItemIsEnabled) # 设置表格不可编辑模式

4.Label

self.ui.userName.setText("当前用户为:" + userName) # 设置Label显示内容

案例如下:

1.生成json数据如下:

import jsonstrData = {'status':200,'message':'获取信息成功!','data':{'userInfo':{'name':"麦嘟小布丁",'sex':'女'},'meetInfo':[{'id': 110,'name': '人工智能技术会议','meet_date': '2019-01-08','meet_time': '16:30:00','meet_address': '会议室A'},{'id': 221,'name': '学习交流会','meet_date': '2018-12-19','meet_time': '14:30:00','meet_address': '会议室B'},{'id': 226,'name': '神经网络知识分享会','meet_date': '2018-12-19','meet_time': '09:00:00','meet_address': '会议室C'}]}
}#定义接口,用来获取json数据
def getMydata():return json.dumps(strData)if __name__ == "__main__":# json.dumps()函数是将字典转化为字符串 jsonStr = json.dumps(strData)#print(jsonStr)# json.loads()函数是将字符串转化为字典res = json.loads(jsonStr)print(type(res),res)

2.Qt designer完成界面设计meetList.ui

为“添加”按钮添加信号和自定义槽函数。

编译meetList.ui为Ui_meetList.py

# -*- coding: utf-8 -*-# Form implementation generated from reading ui file 'c:\Users\lenovo\Desktop\解析Json\meetList.ui'
#
# Created by: PyQt5 UI code generator 5.11.3
#
# WARNING! All changes made in this file will be lost!from PyQt5 import QtCore, QtGui, QtWidgetsclass Ui_MainWindow(object):def setupUi(self, MainWindow):MainWindow.setObjectName("MainWindow")MainWindow.resize(559, 473)MainWindow.setStyleSheet("#MainWindow{background-color: rgb(170, 170, 255);}\n""")self.centralwidget = QtWidgets.QWidget(MainWindow)self.centralwidget.setObjectName("centralwidget")self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)self.tableWidget.setGeometry(QtCore.QRect(30, 60, 491, 211))self.tableWidget.setObjectName("tableWidget")self.tableWidget.setColumnCount(5)self.tableWidget.setRowCount(0)item = QtWidgets.QTableWidgetItem()item.setTextAlignment(QtCore.Qt.AlignCenter)font = QtGui.QFont()font.setBold(True)font.setWeight(75)item.setFont(font)self.tableWidget.setHorizontalHeaderItem(0, item)item = QtWidgets.QTableWidgetItem()item.setTextAlignment(QtCore.Qt.AlignCenter)font = QtGui.QFont()font.setBold(True)font.setWeight(75)item.setFont(font)self.tableWidget.setHorizontalHeaderItem(1, item)item = QtWidgets.QTableWidgetItem()item.setTextAlignment(QtCore.Qt.AlignCenter)font = QtGui.QFont()font.setBold(True)font.setWeight(75)item.setFont(font)self.tableWidget.setHorizontalHeaderItem(2, item)item = QtWidgets.QTableWidgetItem()item.setTextAlignment(QtCore.Qt.AlignCenter)font = QtGui.QFont()font.setBold(True)font.setWeight(75)item.setFont(font)self.tableWidget.setHorizontalHeaderItem(3, item)item = QtWidgets.QTableWidgetItem()item.setTextAlignment(QtCore.Qt.AlignCenter)font = QtGui.QFont()font.setBold(True)font.setWeight(75)item.setFont(font)self.tableWidget.setHorizontalHeaderItem(4, item)self.userName = QtWidgets.QLabel(self.centralwidget)self.userName.setGeometry(QtCore.QRect(400, 30, 141, 20))self.userName.setObjectName("userName")self.label_2 = QtWidgets.QLabel(self.centralwidget)self.label_2.setGeometry(QtCore.QRect(30, 20, 431, 20))font = QtGui.QFont()font.setFamily("微软雅黑")font.setPointSize(14)font.setBold(True)font.setWeight(75)self.label_2.setFont(font)self.label_2.setObjectName("label_2")self.label_3 = QtWidgets.QLabel(self.centralwidget)self.label_3.setGeometry(QtCore.QRect(50, 300, 181, 16))font = QtGui.QFont()font.setPointSize(12)font.setBold(True)font.setWeight(75)self.label_3.setFont(font)self.label_3.setObjectName("label_3")self.label_4 = QtWidgets.QLabel(self.centralwidget)self.label_4.setGeometry(QtCore.QRect(60, 340, 91, 16))font = QtGui.QFont()font.setPointSize(11)self.label_4.setFont(font)self.label_4.setObjectName("label_4")self.label_5 = QtWidgets.QLabel(self.centralwidget)self.label_5.setGeometry(QtCore.QRect(280, 340, 101, 16))font = QtGui.QFont()font.setPointSize(11)self.label_5.setFont(font)self.label_5.setObjectName("label_5")self.label_6 = QtWidgets.QLabel(self.centralwidget)self.label_6.setGeometry(QtCore.QRect(45, 379, 91, 16))font = QtGui.QFont()font.setPointSize(11)self.label_6.setFont(font)self.label_6.setObjectName("label_6")self.label_7 = QtWidgets.QLabel(self.centralwidget)self.label_7.setGeometry(QtCore.QRect(280, 380, 71, 16))font = QtGui.QFont()font.setPointSize(11)self.label_7.setFont(font)self.label_7.setObjectName("label_7")self.addMeetBtn = QtWidgets.QPushButton(self.centralwidget)self.addMeetBtn.setGeometry(QtCore.QRect(450, 300, 75, 23))self.addMeetBtn.setObjectName("addMeetBtn")self.meetId = QtWidgets.QLineEdit(self.centralwidget)self.meetId.setGeometry(QtCore.QRect(120, 340, 151, 20))self.meetId.setObjectName("meetId")self.meetTitle = QtWidgets.QLineEdit(self.centralwidget)self.meetTitle.setGeometry(QtCore.QRect(360, 340, 171, 20))self.meetTitle.setObjectName("meetTitle")self.meetTime = QtWidgets.QLineEdit(self.centralwidget)self.meetTime.setGeometry(QtCore.QRect(120, 380, 151, 20))self.meetTime.setObjectName("meetTime")self.meetAddress = QtWidgets.QLineEdit(self.centralwidget)self.meetAddress.setGeometry(QtCore.QRect(360, 380, 171, 20))self.meetAddress.setObjectName("meetAddress")MainWindow.setCentralWidget(self.centralwidget)self.statusbar = QtWidgets.QStatusBar(MainWindow)self.statusbar.setObjectName("statusbar")MainWindow.setStatusBar(self.statusbar)self.retranslateUi(MainWindow)self.addMeetBtn.clicked.connect(MainWindow.addMeetBtn_clicked)QtCore.QMetaObject.connectSlotsByName(MainWindow)def retranslateUi(self, MainWindow):_translate = QtCore.QCoreApplication.translateMainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))item = self.tableWidget.horizontalHeaderItem(0)item.setText(_translate("MainWindow", "会议id"))item = self.tableWidget.horizontalHeaderItem(1)item.setText(_translate("MainWindow", "会议名称"))item = self.tableWidget.horizontalHeaderItem(2)item.setText(_translate("MainWindow", "会议时间"))item = self.tableWidget.horizontalHeaderItem(3)item.setText(_translate("MainWindow", "会议地点"))item = self.tableWidget.horizontalHeaderItem(4)item.setText(_translate("MainWindow", "备注"))self.userName.setText(_translate("MainWindow", "当前用户为:张三"))self.label_2.setText(_translate("MainWindow", "会议列表信息"))self.label_3.setText(_translate("MainWindow", "新增会议信息"))self.label_4.setText(_translate("MainWindow", "会议id:"))self.label_5.setText(_translate("MainWindow", "会议名称:"))self.label_6.setText(_translate("MainWindow", "会议时间:"))self.label_7.setText(_translate("MainWindow", "会议地点:"))self.addMeetBtn.setText(_translate("MainWindow", "添加"))

3.解析json,将内容显示在tableWidget中 ------ def loadMeetInfo(self)

定义addMeetBtn_clicked()函数,获取LineEdit内容并将内容显示在tableWidget中,每点击添加按钮一次,往当前行的下一行插入数据。

from meetInfo import getMydata
from Ui_meetList import Ui_MainWindow
from PyQt5.QtWidgets import *
import sys
import json
from PyQt5.QtCore import *class MainWin(QMainWindow):def __init__(self):super(MainWin, self).__init__()print("mainwin is called!")self.ui = Ui_MainWindow()self.ui.setupUi(self)self.ui.tableWidget.setColumnCount(5)  # 设置表格的列数# self.ui.tableWidget.setRowCount(100)           #设置表格的行数self.loadMeetInfo()print(f"current rows:{self.ui.tableWidget.currentRow()}")def loadMeetInfo(self):data = getMydata()# 获取信息列表meetData = json.loads(data)['data']# 获取用户信息userInfo = meetData['userInfo']userName = userInfo['name']self.ui.userName.setText("当前用户为:" + userName)# 获取会议详情meetInfo = meetData['meetInfo']# index=0for i, item in enumerate(meetInfo):# index+=1# str(item['id'])将整型转换为字符串self.ui.tableWidget.setRowCount(self.ui.tableWidget.rowCount() + 1)print(self.ui.tableWidget.rowCount())mId = QTableWidgetItem(str(item['id']))mId.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中mId.setFlags(Qt.ItemIsEnabled)  # 设置表格不可编辑模式self.ui.tableWidget.setItem(self.ui.tableWidget.rowCount() - 1, 0, mId)mTitle = QTableWidgetItem(item['name'])mTitle.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中mTitle.setFlags(Qt.ItemIsEnabled)  # 设置表格不可编辑模式self.ui.tableWidget.setItem(self.ui.tableWidget.rowCount() - 1, 1, mTitle)mTime = QTableWidgetItem(item['meet_time'])mTime.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中mTime.setFlags(Qt.ItemIsEnabled)  # 设置表格不可编辑模式self.ui.tableWidget.setItem(self.ui.tableWidget.rowCount() - 1, 2, mTime)mAddress = QTableWidgetItem(item['meet_address'])mAddress.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中mAddress.setFlags(Qt.ItemIsEnabled)  # 设置表格不可编辑模式self.ui.tableWidget.setItem(self.ui.tableWidget.rowCount() - 1, 3, mAddress)# return indexdef addMeetBtn_clicked(self):i = self.ui.tableWidget.rowCount()i += 1self.ui.tableWidget.setRowCount(i)meetId = self.ui.meetId.text()# print(type(meetId))mId = QTableWidgetItem(meetId)mId.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中self.ui.tableWidget.setItem(i - 1, 0, mId)meetTitle = self.ui.meetTitle.text()mTitle = QTableWidgetItem(meetTitle)mTitle.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中self.ui.tableWidget.setItem(i - 1, 1, mTitle)meetTime = self.ui.meetTime.text()mTime = QTableWidgetItem(meetTime)mTime.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中self.ui.tableWidget.setItem(i - 1, 2, mTime)meetAddress = self.ui.meetAddress.text()mAddress = QTableWidgetItem(meetAddress)mAddress.setTextAlignment(Qt.AlignCenter)  # 设置文字显示居中self.ui.tableWidget.setItem(i - 1, 3, mAddress)# LineEdit内容清除self.ui.meetId.setText("")self.ui.meetTitle.setText("")self.ui.meetTime.setText("")self.ui.meetAddress.setText("")if __name__ == "__main__":app = QApplication(sys.argv)main = MainWin()# 显示主界面main.show()sys.exit(app.exec_())

4.结果展示

前3条会议信息为从解析json获得,第4条会议信息为通过新增会议信息添加。

     

这篇关于Pyqt5--解析json并将内容显示在tableWidget的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/412224

相关文章

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实