鱼C论坛

 找回密码
 立即注册
查看: 3528|回复: 8

QTextEdit 表格显示数据

[复制链接]
发表于 2020-9-27 19:50:33 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在学习PYQT5,小白一枚,请教用QTextEdit控件显示数据,数据以表格形式展示,怎么操作好?

数据有:
list1=[“姓名”,“年龄”,“班级”,“学号”]
list2=[("小王","10","一年级","1" ),("小明","11","二年级","2")]

用文本光标中的插入表格insertTable(int rows, int columns) 还是用直接用 Qtextedit中的interHtml(str)好?有代码可以参考吗?如果数据列表比较大且具体行数列数不固定,怎么用函数来填充表格里的内容?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-9-28 00:01:48 | 显示全部楼层
之前看到有个帖子发的是加载excel显示的
可以试试看
  1. from PyQt5 import QtCore, QtGui, QtWidgets
  2. from PyQt5.QtGui import QIcon
  3. from PyQt5.QtWidgets import *
  4. from PyQt5.QtCore import *
  5. import pandas as pd
  6. import numpy as np


  7. class Ui_MainWindow(QMainWindow):

  8.     def __init__(self):
  9.         super(QtWidgets.QMainWindow,self).__init__()
  10.         self.setupUi(self)
  11.         self.retranslateUi(self)

  12.     def setupUi(self, MainWindow):
  13.         MainWindow.setObjectName("MainWindow")
  14.         MainWindow.resize(666, 488)
  15.         self.centralWidget = QtWidgets.QWidget(MainWindow)
  16.         self.centralWidget.setObjectName("centralWidget")
  17.         self.retranslateUi(MainWindow)

  18.         self.tableWidget = QtWidgets.QTableWidget(self.centralWidget)
  19.         self.tableWidget.setGeometry(QtCore.QRect(0, 60, 813, 371))
  20.         self.tableWidget.setObjectName("tableWidget")
  21.         self.tableWidget.setColumnCount(0)
  22.         self.tableWidget.setRowCount(0)
  23.         self.tableWidget.setStyleSheet("selection-background-color:pink")
  24.         self.tableWidget.setEditTriggers(QAbstractItemView.NoEditTriggers)
  25.         self.tableWidget.raise_()

  26.         self.pushButton = QtWidgets.QPushButton(self.centralWidget)
  27.         self.pushButton.setGeometry(QtCore.QRect(90, 20, 75, 23))
  28.         self.pushButton.setObjectName("pushButton")
  29.         self.pushButton.setText("打开")
  30.         MainWindow.setCentralWidget(self.centralWidget)
  31.         QtCore.QMetaObject.connectSlotsByName(MainWindow)

  32.         self.pushButton.clicked.connect(self.openfile)
  33.         self.pushButton.clicked.connect(self.creat_table_show)

  34.     def retranslateUi(self, MainWindow):
  35.         _translate = QtCore.QCoreApplication.translate
  36.         MainWindow.setWindowTitle(_translate("MainWindow", "一颗数据小白菜"))


  37.     def openfile(self):

  38.         ###获取路径===================================================================

  39.         openfile_name = QFileDialog.getOpenFileName(self,'选择文件','','Excel files(*.xlsx , *.xls)')

  40.         #print(openfile_name)
  41.         global path_openfile_name


  42.         ###获取路径====================================================================

  43.         path_openfile_name = openfile_name[0]


  44.     def creat_table_show(self):
  45.         ###===========读取表格,转换表格,===========================================
  46.         if len(path_openfile_name) > 0:
  47.             input_table = pd.read_excel(path_openfile_name)
  48.         #print(input_table)
  49.             input_table_rows = input_table.shape[0]
  50.             input_table_colunms = input_table.shape[1]
  51.         #print(input_table_rows)
  52.         #print(input_table_colunms)
  53.             input_table_header = input_table.columns.values.tolist()
  54.         #print(input_table_header)

  55.         ###===========读取表格,转换表格,============================================
  56.         ###======================给tablewidget设置行列表头============================

  57.             self.tableWidget.setColumnCount(input_table_colunms)
  58.             self.tableWidget.setRowCount(input_table_rows)
  59.             self.tableWidget.setHorizontalHeaderLabels(input_table_header)

  60.         ###======================给tablewidget设置行列表头============================

  61.         ###================遍历表格每个元素,同时添加到tablewidget中========================
  62.             for i in range(input_table_rows):
  63.                 input_table_rows_values = input_table.iloc[[i]]
  64.                 #print(input_table_rows_values)
  65.                 input_table_rows_values_array = np.array(input_table_rows_values)
  66.                 input_table_rows_values_list = input_table_rows_values_array.tolist()[0]
  67.             #print(input_table_rows_values_list)
  68.                 for j in range(input_table_colunms):
  69.                     input_table_items_list = input_table_rows_values_list[j]
  70.                 #print(input_table_items_list)
  71.                 # print(type(input_table_items_list))

  72.         ###==============将遍历的元素添加到tablewidget中并显示=======================

  73.                     input_table_items = str(input_table_items_list)
  74.                     newItem = QTableWidgetItem(input_table_items)
  75.                     newItem.setTextAlignment(Qt.AlignHCenter|Qt.AlignVCenter)
  76.                     self.tableWidget.setItem(i, j, newItem)  

  77.         ###================遍历表格每个元素,同时添加到tablewidget中========================
  78.         else:
  79.             self.centralWidget.show()

  80. if __name__ == "__main__":
  81.     import sys
  82.     app = QtWidgets.QApplication(sys.argv)
  83.     MainWindow = QtWidgets.QMainWindow()
  84.     ui = Ui_MainWindow()
  85.     ui.setupUi(MainWindow)
  86.     MainWindow.show()
  87.     sys.exit(app.exec_())
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-29 16:55:15 | 显示全部楼层
疾风怪盗 发表于 2020-9-28 00:01
之前看到有个帖子发的是加载excel显示的
可以试试看

谢谢。但我想用Qtextedit控件显示,因为用Qtextedit除了可以显示表格,还可以显示其他富文本
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-29 17:27:27 | 显示全部楼层
香辣烤鱿鱼 发表于 2020-9-29 16:55
谢谢。但我想用Qtextedit控件显示,因为用Qtextedit除了可以显示表格,还可以显示其他富文本

网上找到这个代码,是不是你需要的?

  1. # -*- coding:utf-8 -*-
  2. # Time : 2019/08/11 上午 11:57
  3. # Author : 御承扬
  4. # e-mail:2923616405@qq.com
  5. # project:  PyQt5
  6. # File : qt13_textEdit.py
  7. # @software: PyCharm

  8. from PyQt5.QtGui import QIcon
  9. from PyQt5.QtWidgets import QApplication, QWidget, QTextEdit, QVBoxLayout, QPushButton
  10. import sys


  11. class TextEditDemo(QWidget):
  12.     def __init__(self, parent=None):
  13.         super(TextEditDemo, self).__init__(parent)
  14.         self.setWindowTitle("QTextEdit 例子")
  15.         self.resize(300, 270)
  16.         self.textEdit = QTextEdit()
  17.         self.btnPress2 = QPushButton("显示 HTML")
  18.         layout = QVBoxLayout()
  19.         layout.addWidget(self.textEdit)
  20.         layout.addWidget(self.btnPress2)
  21.         self.setLayout(layout)

  22.         self.btnPress2.clicked.connect(self.btnPress2_Clicked)


  23.     def btnPress2_Clicked(self):
  24.         self.textEdit.setHtml(
  25.             "<table border='1' cellpadding='10'>"
  26.             " <tr>   <td>编号</td>   <td>课程名称</td>   <td>成绩</td>    <td>学分</td>   <td>绩点</td> </tr> "
  27.             " <tr>   <td> 1 </td>   <td>1</td>   <td>2</td>    <td>3</td>   <td>4</td> </tr> "
  28.             
  29.             "</table> "
  30.         )


  31. if __name__ == "__main__":
  32.     app = QApplication(sys.argv)
  33.     win = TextEditDemo()
  34.     win.show()
  35.     sys.exit(app.exec_())
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-10 09:34:14 | 显示全部楼层
疾风怪盗 发表于 2020-9-29 17:27
网上找到这个代码,是不是你需要的?

有帮助,是用setHtml方式实现。其实我是想插入表格的同时,将list1、list2的数据也填充上去,不是一个一个字符的填上去,这样填表格的内容、行数、列数是固定的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-10 09:42:39 From FishC Mobile | 显示全部楼层
香辣烤鱿鱼 发表于 2020-10-10 09:34
有帮助,是用setHtml方式实现。其实我是想插入表格的同时,将list1、list2的数据也填充上去,不 ...

只找到这样的,我也不会了,你再自己研究下吧
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-10 10:31:57 | 显示全部楼层
本帖最后由 疾风怪盗 于 2020-10-10 10:38 编辑
香辣烤鱿鱼 发表于 2020-10-10 09:34
有帮助,是用setHtml方式实现。其实我是想插入表格的同时,将list1、list2的数据也填充上去,不 ...


你意思是要把你的数据填上去吧?

我贴上来的代码表格内数据瞎写额,就是个演示啊

你自己的数据可以填充上去啊,用f'list[0]'这样的形式不就可以了么
  1.     def btnPress2_Clicked(self):
  2.         list1=[1,2,3,4,5]
  3.         list2=[9,8,7,6,5]
  4.         self.textEdit.setHtml(
  5.             "<table border='1' cellpadding='10'>"
  6.             " <tr>   <td>编号</td>   <td>课程名称</td>   <td>成绩</td>    <td>学分</td>   <td>绩点</td> </tr> "
  7.             f" <tr>   <td> {list1[0]} </td>   <td>{list1[1]}</td>   <td>{list1[2]}</td>    <td>{list1[3]}</td>   <td>{list1[4]}</td> </tr> "
  8.             f" <tr>   <td> {list2[0]} </td>   <td>{list2[1]}</td>   <td>{list2[2]}</td>    <td>{list2[3]}</td>   <td>{list2[4]}</td> </tr> "
  9.             "</table> "
  10.         )
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-13 18:25:14 | 显示全部楼层
疾风怪盗 发表于 2020-10-10 10:31
你意思是要把你的数据填上去吧?

我贴上来的代码表格内数据瞎写额,就是个演示啊

对,用f'list[0]'这样的形式可以,但是行数列数是固定的。因为我获取的列表行数跟列数是不固定的,是一个搜索结果
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-13 18:27:29 | 显示全部楼层
疾风怪盗 发表于 2020-10-10 09:42
只找到这样的,我也不会了,你再自己研究下吧

感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-28 08:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表