当前位置: 首页 > news >正文

PyInstaller 打包后 Excel 转 CSV 报错解决方案:“excel file format cannot be determined“

一、问题背景
在使用 Python 开发 Excel 转 CSV 工具时,直接运行脚本(python script.py)可以正常工作,但通过 PyInstaller 打包成可执行文件后,出现以下报错:
excel file format cannot be determined, you must specify an engine manually

该问题通常发生在使用pandas.read_excel()读取 Excel 文件时,打包后的程序无法自动识别文件格式所需的解析引擎。
二、问题原因分析

  1. Pandas 引擎自动检测失效
    Pandas 处理 Excel 文件时依赖外部库:
    .xlsx格式需openpyxl
    .xls格式需xlrd直接运行时 Pandas 会自动检测扩展名并调用对应引擎,但打包后依赖库可能未正确包含,导致引擎检测失败。
  2. 打包工具未包含依赖
    PyInstaller 默认不会自动识别openpyxl/xlrd等非核心依赖,导致打包后的程序缺少必要模块。
    三、分步解决方案
    方案 1:显式指定 Excel 解析引擎(核心修复)
    修改代码,根据文件扩展名强制指定解析引擎,避免 Pandas 自动检测:
    import pandas as pd

读取Excel时增加引擎判断逻辑

if excel_path.lower().endswith(‘.xlsx’):
df = pd.read_excel(excel_path, sheet_name=sheet, engine=‘openpyxl’)
elif excel_path.lower().endswith(‘.xls’):
df

http://www.dtcms.com/a/188925.html

相关文章:

  • uniapp(vue3)动态计算swiper高度封装自定义hook
  • Foupk3systemX5OS TXW8移动设备
  • UE5中制作动态数字Decal
  • While语句数数字
  • 互信息:揭秘变量间的隐藏关联
  • 5.13本日总结
  • windows 强行终止进程,根据端口号
  • 【Linux 系统调试】系统的动态跟踪工具--SystemTap
  • 系统平衡与企业挑战
  • C++ 字符格式化输出
  • Linux 系统安全基线检查:入侵防范测试标准与漏洞修复方法
  • 【递归、搜索与回溯】专题一:递归(二)
  • SparkSQL 连接 MySQL 并添加新数据:实战指南
  • 微服务八股(自用)
  • hashicorp vault机密管理系统的国产化替代:安当SMS凭据管理系统,量子安全赋能企业密钥管理
  • 软考软件测评师——计算机网络
  • 【Pandas】pandas DataFrame cummin
  • NC报销单保存时,报”保存失败:fail to save VO Array ~#@“
  • SQL中联表的运用
  • EXCEL下拉菜单与交替上色设置
  • ElasticSeach快速上手笔记-入门篇
  • 为什么 import _ “github.com/go-sql-driver/mysql“ 要导入但不使用?_ 是什么意思?
  • 中电金信参编的国家标准《信息技术 中间件 消息中间件技术要求》正式发布
  • 1.3 不确定性分析
  • 云蝠智能大模型呼叫优势:技术驱动全链路升级,重塑智能交互服务新体验
  • 【JavaScript】原生 JavaScript 实现 localStorage 过期时间
  • ubuntu----100,常用命令2
  • 裸机开发的核心技术:轮询、中断与DMA
  • 定制化项目变更通知延误、流程失控?日事清用条件分支判断规范跨部门协作与变更管理流程
  • STM32 __main