Python程序打包exe报错


在py文件所处的路径下输入cmd,进入文件夹的终端进行打包
# 带有终端窗口
pyinstaller -F xxx.py

# 不带终端窗口
pyinstaller -F -w xxx.py

解决方法(一):检查你的Pyinstaller版本和Python版本或者第三方库版本是否匹配,如果不匹配,尝试卸载重新安装合适的版本

1.查看pyinstallar版本

pyinstaller --version
提示The ‘pathlib’ package is an obsolete backport of a standard library package and is incompatible with PyInstaller.
conda remove pathlib卸载pathlib,提示The following packages will be UPDATED,输入y。
继续查看pyinstaller --version,Please install pywin32-ctypes.用pip install pywin32-ctypes提示已安装,用conda install pywin32-ctypes成功安装。
pyinstaller --version
5.13.0

2 查看Python版本

python --version
Python 3.10.12

尝试

1.编辑 python 目录/Libs/dis.py,找到 def _unpack_opargs,将 else 部分增加一行
extended_arg = 0
https://zhuanlan.zhihu.com/p/438387547
发现文件里已存在这行
2.查看5.13.0 pyinstaller官方文档,发现支持3.10.12版本的python,也能在win10上运行
在这里插入图片描述
https://pypi.org/project/pyinstaller/

解决方法(二):修改你的Python安装路径或者打包文件路径,确保没有中文或者空格

C:\Users\zzfs\Desktop\test
依然无法运行

解决方法(三)重装Anaconda

没用

解决方法(四)在Anaconda Prompt里打包

没用

解决方法(五) 加日志记录问题

日志提示
File “pandas\core\generic.py”, line 5989, in getattr
AttributeError: ‘DataFrame’ object has no attribute ‘append’
pandas版本升级弃用了 老版本’DataFrame’的append方法。
#position_detail=position_detail.append(pd.Series(c3, index=position_detail.columns), ignore_index=True)
改成
position_detail=pd.concat([position_detail, pd.DataFrame([pd.Series(c3, index=position_detail.columns)])], ignore_index=True)

解决了。

可能是安装anaconda时同时安装了3.10版本的Python,但我之前单独安装过3.11版本的,spyder编译器里面内置的pandas包的版本 跟 打包时的pandas包不一样。

改成

report_df = pd.DataFrame(columns=column_names)
for row in ws.iter_rows(min_row=4, values_only=True):
#print(row)
#report_df=report_df.append(pd.Series(row), ignore_index=True)
report_df.loc[len(report_df)] = row

改成
max_columns = 0 # 记录拆分后的最大列数
new_rows = []
for i in range(0, len(column_data)):
split_data = re.split(pattern, column_data.iloc[i]) # 使用正则表达式拆分数据
if len(split_data) > max_columns:
max_columns = len(split_data)
new_rows.append(split_data)
#hkex_txt3 = hkex_txt3.append(pd.Series(split_data), ignore_index=True)
new_df = pd.DataFrame(new_rows)
hkex_txt3 = pd.concat([hkex_txt3, new_df], ignore_index=True)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值