自动化瓦力多渠道打包python脚本
目录介绍
- 1.本库优势亮点
- 2.使用介绍
- 3.注意要点
- 4.效果展示
- 5.其他介绍
0.首先看看我录制的案例演示
-
如下所示,这段python代码很简单,工具十分强大,一键多渠道打包工具。
1.本库优势亮点
- 通过该自动化脚本,自需要run一下或者命令行运行脚本即可实现美团瓦力多渠道打包,打包速度很快
- 配置信息十分简单,代码中已经注释十分详细。Keystore信息一定要配置,至于渠道apk输出路径,文件配置路径等均有默认路径,没有配置也没关系
- 针对输出路径是根目录下的output文件夹,文件不存在则创建,文件存在则是先删除之前多渠道打包生成的【也就是删除output文件夹下所有文件】,然后在重新生成
- 多渠道的定义是在channel这个文件中,建议是txt文件格式,你可以根据项目情况修改,十分快捷
- 如果瓦力打包工具更新了,直接替换一下lib中的jar即可。可以在python3.x上跑起来!
- 我也参考了大量的博客,网上博客很多,我始终觉得对于这种实操性很强的案例,还是博客和项目一起学习才效果更好。感谢无数的前辈大神!
2.使用介绍
-
第一步:准备基础的文件
- 将你加固好的apk文件,keystore,已经需要多渠道配置信息的channel放到指定的apk文件中
- 初步建议,如果你想自定义存放文件的路径,可以先熟悉一下python的代码再做修改,也没有什么难度
-
第二步:配置Config.py文件中的属性
- 配置keystore信息,这个地方引用你的keystore信息
# keystore信息 # Windows 下路径分割线请注意使用\\转义 keystorePath = "D:\\GitHub\\YCWalleHelper\\venv\\Include\\apk\\ycPlayer.jks" keyAlias = "yc" keystorePassword = "19930211" keyPassword = "19930211"
- 配置其他信息,比如apk的名称,渠道包配置路径,输出路径等等
# 加固后的源文件名(未重签名) # 必须要配置 protectedSourceApkName = "app_release_aligned_signed.apk" # 下面这些可以不用配置,代码中会有默认的值 # 加固后的源文件所在文件夹路径(...path),注意结尾不要带分隔符,默认在此文件夹根目录 protectedSourceApkDirPath = "" # 渠道包输出路径,默认在此文件夹output目录下 channelsOutputFilePath = "" # 渠道名配置文件路径,默认在此文件夹apk目录下 channelFilePath = "" # 额外信息配置文件(绝对路径) # 配置信息示例参看,默认是此文件夹apk目录下 extraChannelFilePath = "" # Android SDK buidtools path , please use above 25.0+ # 必须配置 sdkBuildToolPath = "D:\\Program File\\AndroidSdk\\build-tools\\28.0.3"
-
第三步:直接运行
- 第一种方式是通过PyCharm工具运行,这个直接run就可以呢。程序员建议使用这种!
- 第二种方式是通过命令行运行,就可以实现自动化打包
python MainWalle.py
-
第四步:修改多渠道配置信息
- 直接找到channel文件,进行修改即可,注意格式!
360 #360 91anzhuo # 91安卓 anzhuo # 安卓 baidu # 百度 wandoujia # 豌豆荚 xiaoyangdoubi #小杨逗比 yingyongbao # 应用宝
3.注意要点
3.1 注意在apk目录中一定要放入channel,keystore,还有加固的apk文件
- channel是指指定多渠道信息
- keystore是指你要签名的apk的钥匙
- apk是指你需要进行多渠道打包的加固文件。注意apk文件名称要和Config配置的apk名称要一致。
3.2 配置keystore信息需要注意的问题
-
主要是注意路径是全路径
# keystore信息 # Windows 下路径分割线请注意使用\\转义 keystorePath = "D:\\GitHub\\YCWalleHelper\\venv\\Include\\apk\\ycPlayer.jks" keyAlias = "yc" keystorePassword = "19930211" keyPassword = "19930211"
3.3 注意apk下存放的apk文件名称和Config.py中配置的apk名称要相同
-
看下面这个截图
3.4 关于部分疑问问题
- 关于Config.py中的sdkBuildToolPath,建议和你使用studio的版本保持一致。别忽略这种小的问题!
- 注意如果要配置定义路径等属性,由于编码格式为UTF-8,所以不要带异常字符
- 多渠道打包时,如果要修改多渠道信息,直接修改channel,这个文件就不要修改成其他的名称呢!
4.效果展示
-
如图所示,建议你亲自尝试一下,特别好玩!
5.其他介绍
关于其他内容介绍
关于博客汇总链接
其他推荐
- 博客笔记大汇总【15年10月到至今】,包括Java基础及深入知识点,Android技术博客,Python学习笔记等等,还包括平时开发中遇到的bug汇总,当然也在工作之余收集了大量的面试题,长期更新维护并且修正,持续完善……开源的文件是markdown格式的!同时也开源了生活博客,从12年起,积累共计47篇[近20万字],转载请注明出处,谢谢!
- 链接地址:https://github.com/yangchong2...
- 如果觉得好,可以star一下,谢谢!当然也欢迎提出建议,万事起于忽微,量变引起质变!
参考博客
- https://github.com/Meituan-Di...
- https://blog.csdn.net/ruancod...
- https://www.cnblogs.com/moran...
- https://www.jianshu.com/p/b5b...
- https://www.jianshu.com/p/20a...
- https://github.com/Jay-Goo/Pr...
- https://blog.csdn.net/u013692...
关于LICENSE
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。