香辣烤鱿鱼 发表于 2020-9-27 19:50:33

QTextEdit 表格显示数据

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

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

用文本光标中的插入表格insertTable(int rows, int columns) 还是用直接用 Qtextedit中的interHtml(str)好?有代码可以参考吗?如果数据列表比较大且具体行数列数不固定,怎么用函数来填充表格里的内容?

疾风怪盗 发表于 2020-9-28 00:01:48

之前看到有个帖子发的是加载excel显示的
可以试试看
from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import pandas as pd
import numpy as np


class Ui_MainWindow(QMainWindow):

    def __init__(self):
      super(QtWidgets.QMainWindow,self).__init__()
      self.setupUi(self)
      self.retranslateUi(self)

    def setupUi(self, MainWindow):
      MainWindow.setObjectName("MainWindow")
      MainWindow.resize(666, 488)
      self.centralWidget = QtWidgets.QWidget(MainWindow)
      self.centralWidget.setObjectName("centralWidget")
      self.retranslateUi(MainWindow)

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

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

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

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


    def openfile(self):

      ###获取路径===================================================================

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

      #print(openfile_name)
      global path_openfile_name


      ###获取路径====================================================================

      path_openfile_name = openfile_name


    def creat_table_show(self):
      ###===========读取表格,转换表格,===========================================
      if len(path_openfile_name) > 0:
            input_table = pd.read_excel(path_openfile_name)
      #print(input_table)
            input_table_rows = input_table.shape
            input_table_colunms = input_table.shape
      #print(input_table_rows)
      #print(input_table_colunms)
            input_table_header = input_table.columns.values.tolist()
      #print(input_table_header)

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

            self.tableWidget.setColumnCount(input_table_colunms)
            self.tableWidget.setRowCount(input_table_rows)
            self.tableWidget.setHorizontalHeaderLabels(input_table_header)

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

      ###================遍历表格每个元素,同时添加到tablewidget中========================
            for i in range(input_table_rows):
                input_table_rows_values = input_table.iloc[]
                #print(input_table_rows_values)
                input_table_rows_values_array = np.array(input_table_rows_values)
                input_table_rows_values_list = input_table_rows_values_array.tolist()
            #print(input_table_rows_values_list)
                for j in range(input_table_colunms):
                  input_table_items_list = input_table_rows_values_list
                #print(input_table_items_list)
                # print(type(input_table_items_list))

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

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

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

if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

香辣烤鱿鱼 发表于 2020-9-29 16:55:15

疾风怪盗 发表于 2020-9-28 00:01
之前看到有个帖子发的是加载excel显示的
可以试试看

谢谢。但我想用Qtextedit控件显示,因为用Qtextedit除了可以显示表格,还可以显示其他富文本{:5_100:}

疾风怪盗 发表于 2020-9-29 17:27:27

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

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

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

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


class TextEditDemo(QWidget):
    def __init__(self, parent=None):
      super(TextEditDemo, self).__init__(parent)
      self.setWindowTitle("QTextEdit 例子")
      self.resize(300, 270)
      self.textEdit = QTextEdit()
      self.btnPress2 = QPushButton("显示 HTML")
      layout = QVBoxLayout()
      layout.addWidget(self.textEdit)
      layout.addWidget(self.btnPress2)
      self.setLayout(layout)

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


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


if __name__ == "__main__":
    app = QApplication(sys.argv)
    win = TextEditDemo()
    win.show()
    sys.exit(app.exec_())

香辣烤鱿鱼 发表于 2020-10-10 09:34:14

疾风怪盗 发表于 2020-9-29 17:27
网上找到这个代码,是不是你需要的?

有帮助,是用setHtml方式实现{:5_109:}。其实我是想插入表格的同时,将list1、list2的数据也填充上去,不是一个一个字符的填上去,这样填表格的内容、行数、列数是固定的

疾风怪盗 发表于 2020-10-10 09:42:39

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

只找到这样的,我也不会了,你再自己研究下吧

疾风怪盗 发表于 2020-10-10 10:31:57

本帖最后由 疾风怪盗 于 2020-10-10 10:38 编辑

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

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

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

你自己的数据可以填充上去啊,用f'list'这样的形式不就可以了么
    def btnPress2_Clicked(self):
      list1=
      list2=
      self.textEdit.setHtml(
            "<table border='1' cellpadding='10'>"
            " <tr>   <td>编号</td>   <td>课程名称</td>   <td>成绩</td>    <td>学分</td>   <td>绩点</td> </tr> "
            f" <tr>   <td> {list1} </td>   <td>{list1}</td>   <td>{list1}</td>    <td>{list1}</td>   <td>{list1}</td> </tr> "
            f" <tr>   <td> {list2} </td>   <td>{list2}</td>   <td>{list2}</td>    <td>{list2}</td>   <td>{list2}</td> </tr> "
            "</table> "
      )

香辣烤鱿鱼 发表于 2020-10-13 18:25:14

疾风怪盗 发表于 2020-10-10 10:31
你意思是要把你的数据填上去吧?

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


对,用f'list'这样的形式可以,但是行数列数是固定的。因为我获取的列表行数跟列数是不固定的,是一个搜索结果{:5_100:}

香辣烤鱿鱼 发表于 2020-10-13 18:27:29

疾风怪盗 发表于 2020-10-10 09:42
只找到这样的,我也不会了,你再自己研究下吧

感谢{:5_91:}
页: [1]
查看完整版本: QTextEdit 表格显示数据