码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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 

  • 相关阅读:
    Android 9.0 pms中关于启动app时获取app的ActivityInfo信息相关源码分析
    【贪心算法】贪心算法任务调度具体应用详解与示例
    Lock 锁底层实现
    [附源码]java毕业设计校医院病人跟踪治疗信息管理系统
    豆瓣评分9.0,《Java核心技术与面试》神作,已帮助1374人拿到Offer
    Observer
    Linux(Centos7)服务器中配置Mysql主从数据库,以及数据库的安装,防火墙操作
    Tomcat长轮询原理与源码解析
    Win32窗口设置为透明
    【Flink实战】用户统计:按照省份维度统计新老用户
  • 原文地址:https://blog.csdn.net/belldeep/article/details/133715486
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号