简单了解一下argparse和pyinstaller
今天我们学习两个新东西
- argparse
- pyinstaller 那么,在开始之前我们要知道他俩是干啥的?
argparse
argparse是命令行参数解析模块,不知道大家有没有见过这种场景
可以看到hugo这个命令行有很多参数,在执行命令时,传入不同的命令即可执行hugo内部相应的逻辑。
pyinstaller
pyinstaller 是py打包组件,一般情况下,我们都是基于Python环境,然后使用类似Python demo.py这种方式来执行,但是,一般我们编写好脚本发给其他人用的时候,如果还让使用者也装一个Python环境的话,是不是有点麻烦呢?这里,pyinstaller这个工具就能帮解决这个问题,它可以把相应的py文件和依赖包打包成exe文件,使用者直接双击即可
基于argparse实现简单的命令行工具
还记得上次说的Python实现简单的Execl多个Sheet表格合并这个东西呢?我们在程序里面把我们的路径写死了,但是,实际场景可能路径是不固定的,那么这里就借助argparse来实现动态传参,先来个简单的示例吧
import argparseparser = argparse.ArgumentParser()parser.add_argument('-p','-path', help='path help') # 添加参数parser.add_argument('-f','-filename', help='filename help') args = parser.parse_args()print(args.p) # 打印参数print(args.f)
这里,我们使用argparse弄个简单的命令行程序,这里我们继续结合上次的程序,稍作修改,
import pandas as pdfrom pandas import DataFrameimport xlrdimport osimport argparsefrom pathlib import Pathparser = argparse.ArgumentParser()parser.add_argument('-p', '-path', help='path help')parser.add_argument('-f', '-filename', help='filename help')args = parser.parse_args()file_path = args.pfile_name = args.fpath=Path(file_path)if not path.exists() : print('目录不存在') exit()if file_name.strip()=='': print('文件名必传') exit()files = os.listdir(file_path) # 获取指定目录下的文件df = DataFrame()for file in files: wb = xlrd.open_workbook(file_path+file) # 打开execl文件 sheets = wb.sheet_names() # 获取sheets名称 for sheet in sheets: df = pd.concat([df, pd.read_excel( file_path+file, sheet_name=sheet, encoding='utf8')]) # 拼接sheets内容df.to_excel('{}{}.xls'.format(file_path,file_name)) # 保存execl文件 需要依赖xlwt组件print('保存成功')
使用pyinstaller将py脚本打包成exe可执行文件
在使用之前,需要执行pip install pyinstaller 进行安装
当然,还有其他的安装方式,只是我觉得pip安装最方便,现在,我们就来把上面的程序打包成exe文件,首先需要通过cmd命令窗口进入到我们的py文件所在目录,然后执行pyinstaller -F demo.py(因为我的demo.py在D盘根目录下)
打包成功后,会在我们的所在目录生成一个dist文件,打包好的exe就生成在dist文件夹中,
现在我们到dist目录中去执行命令
如果是其他电脑需要使用的话,直接将这个demo.exe用类似的命令启动即可。
这里只是简单的使用了argparse和pyinstaller,后面我们可能会经常跟pyinstaller打交道的,所以更多高深用法,我们后面继续探讨。
我只是记录我的学习过程,由于书读的少,可能很多地方表述或者是理解得不对,请轻喷并指正。