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

相关文章

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象