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 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.