• pyqt5:openpyxl 读取 Excel文件,显示在 QTableWidget 中


    pip install openpyxl
    openpyxl-3.1.2-py2.py3-none-any.whl (249 kB)
    et_xmlfile-1.1.0-py3-none-any.whl (4.7 kB)
    摘要:A Python library to read/write Excel 2010 xlsx/xlsm files

    pip install pyqt5
    pip install pyqt5-tools; 

    编写 openpyxl_pyqt5.py 如下

    1. # -*- coding: utf-8 -*-
    2. import os
    3. import sys
    4. from PyQt5.QtWidgets import QApplication, QMainWindow, QFileDialog, QMessageBox
    5. from PyQt5.QtWidgets import QTableWidget, QTableWidgetItem
    6. from openpyxl import load_workbook
    7. class ExcelReader(QMainWindow):
    8. def __init__(self):
    9. super().__init__()
    10. # 设置窗口属性
    11. self.setWindowTitle("Excel Reader")
    12. self.setGeometry(100, 100, 800, 600)
    13. # 选择.xlsx文件名
    14. file_name, _ = QFileDialog.getOpenFileName(self, "Open Excel File", "", "xlsx Files (*.xlsx)")
    15. if file_name:
    16. self.file_path = file_name
    17. else:
    18. sys.exit(1)
    19. if not os.path.exists(self.file_path):
    20. print(f'Error: {self.file_path} not found.')
    21. sys.exit(2)
    22. # 加载Excel文件
    23. book = load_workbook(filename=self.file_path)
    24. sheet = book.active
    25. nrows = sheet.max_row # 取最大行数
    26. ncols = sheet.max_column # 取最大列数
    27. if ncols > 26:
    28. print(f" columns: {ncols} > 26 !")
    29. ncols = 26
    30. # 创建表格控件
    31. self.table = QTableWidget()
    32. self.table.setRowCount(nrows) # 设置行数
    33. self.table.setColumnCount(ncols) # 设置列数
    34. headers = tuple("ABCDEFGHIJKLMNOPQRSTUVWXYZ")
    35. self.table.setHorizontalHeaderLabels(headers[0:ncols])
    36. self.setCentralWidget(self.table)
    37. # 遍历Excel数据并插入到表格控件中
    38. row = 0
    39. for row_data in sheet.iter_rows():
    40. col = 0
    41. for cell in row_data:
    42. v = cell.value
    43. t = cell.data_type
    44. if v is None:
    45. item = QTableWidgetItem('')
    46. elif t in ('s','t'): # str, text
    47. item = QTableWidgetItem(v)
    48. elif t =='n': # number
    49. if v%1 ==0: # int
    50. item = QTableWidgetItem("%d" %v)
    51. else: # float
    52. item = QTableWidgetItem("%.4f" %v)
    53. elif t =='d': # date
    54. item = QTableWidgetItem(v.strftime('%Y-%m-%d'))
    55. else:
    56. item = QTableWidgetItem(str(v))
    57. self.table.setItem(row, col, item)
    58. col += 1
    59. row += 1
    60. #
    61. if __name__ == "__main__":
    62. app = QApplication(sys.argv)
    63. reader = ExcelReader()
    64. reader.show()
    65. sys.exit(app.exec_())

    运行 python openpyxl_pyqt5.py 

  • 相关阅读:
    工作总结:kafka踩过的坑
    Flask 处理响应
    HMS Core 视频编辑服务开放模板能力,助力用户一键Get同款酷炫视频
    【Linux】文件系统中inode与软硬链接以及读写权限问题
    根据模板动态生成word(一)使用freemarker生成word
    项目启动 | 宏昌电器牵手盘古信息,数字化制造引领企业高质量发展
    c基础2-extern
    web测试——业务测试2
    吐血整理python数据分析利器pandas的八个生命周期!
    一分钟了解期权合约转仓交易的流程
  • 原文地址:https://blog.csdn.net/belldeep/article/details/133715486