使用pyinstaller打包excel、txt等文件,写入到当前目录,并读取打包配置文件2. 使用说明
创建 py文件,在Python环境下打包
pyinstaller -F -c --hidden-import pandas --hidden-import="pandas._libs.tslibs.timedeltas" --hidden-import="pandas._libs.tslibs.np_datetime" --hidden-import="pandas._libs.tslibs.nattype" --hidden-import="pandas._libs.skiplist" -i f8.ico func_test.py
# 激活虚拟环境
conda activate proj_for_pack
# 进入到目标py文件目录中 func_test.py
cd C:UsersrxdrdDesktopprojlearn
# 执行打包命令 -i 表示添加程序图标
pyinstaller -F -c --hidden-import pandas --hidden-import="pandas._libs.tslibs.timedeltas" --hidden-import="pandas._libs.tslibs.np_datetime" --hidden-import="pandas._libs.tslibs.nattype" --hidden-import="pandas._libs.skiplist" -i f8.ico func_test.py
# 修改func_test.spec 将需要打包的文件路径写入 datas
# 如打包文件夹为 'data_src' 修改 datas=[('data_src', 'data_src')]
pyinstaller -F func_test.spec -c --hidden-import pandas --hidden-import="pandas._libs.tslibs.timedeltas" --hidden-import="pandas._libs.tslibs.np_datetime" --hidden-import="pandas._libs.tslibs.nattype" --hidden-import="pandas._libs.skiplist"
3.Python实例代码
#coding:utf-8
import sys
import os
from shutil import copy
import configparser
# 获取文件路径
def resource_path(relative_path):
if getattr(sys, 'frozen', False): #是否Bundle Resource
base_path = sys._MEIPASS
else:
base_path = os.path.abspath(".")
return os.path.join(base_path, relative_path)
#访问res文件夹下a.txt的内容
print(filename)
with open(filename) as f:
lines = f.readlines()
print(lines)
f.close()
# 打包路径中的 ./data_src/a.txt
f_name1 = resource_path(os.path.join("data_src","a.txt"))
print(f_name1)
#
with open(f_name1) as f:
lines = f.readlines()
print(lines)
f.close()
# 复制打包文件到 当前目录
copy(f_name1, 'a.txt')
# 读取打包路径下的配置文件 ./data_src/config.ini
cf = configparser.ConfigParser()
conf_path = resource_path(os.path.join("data_src","config.ini"))
print(conf_path)
cf.read(conf_path)
print('get:' ,' ' , cf.get('IP', 'host'))
# 结果 get: 192.168.1.1



