前言

这段时间刚刚学习了一段时间的Python,加上自己是做iOS开发的,就想着用Python来做一个自动化打包,可以自动完成打包,上传到蒲公英,并且发送邮箱给测试人员.

一是可以减少打包功夫,二来可以练练手,结合自己的工作来输出一点东西.废话不多说,直接上代码...

原理

就是使用xcodebuild来控制Xcode进行一系列的操作,从而完成打包的操作.

为什么要做这个?

在我们日常开发的时候,特别是在内部测试的时间,有可能需要频繁的打包,打包的工作比较繁琐,需要等待点击下一步,选择之类,影响了开发的节奏.(开玩笑,我能有啥节奏...), 为什么不能直接运行,然后完成所有的操作呢?

思路:

从网上查找了一些关于xcodebuild来打包的资料,从而得到:

找到对应的项目

clean项目

archive项目

export IPA

上传蒲公英

发送邮件

收工

思路有了,动手起来.

运行环境

Python, Xcode

这些需要大家直接去搭建好环境...

准备工作

下载安装pycharm(这只是我开发Python的工具而已,大家可以根据自己喜欢的来选择)

注册并认证蒲公英(不认证的话,是不能上传的)

邮箱开启POP3/SMTP服务(我使用的是QQ邮箱),记录下16位授权码

一个ExportOptions.plist文件, 这个下面会解释为什么需要还有怎么生成!

一份iOS项目代码→_→

完整代码

#!/usr/bin/env python3

# -*- coding: utf-8 -*-

# @Time : 2018/11/14 11:04 AM

# @Author : liangk

# @Site :

# @File : auto_archive_ios.py

# @Software: PyCharm

import os

import requests

import webbrowser

import subprocess

import time

import smtplib

from email.mime.text import MIMEText

from email import encoders

from email.header import Header

from email.utils import parseaddr, formataddr

project_name = 'TestArchive' # 项目名称

archive_workspace_path = '/Users/用户/Desktop/TestArchive' # 项目路径

export_directory = 'archive' # 输出的文件夹

ipa_download_url = 'https://www.pgyer.com/XXX' #蒲公英的APP地址

# 蒲公英账号USER_KEY、API_KEY

USER_KEY = 'XXXXXXXXXXXXXXXXXXXX'

API_KEY = 'XXXXXXXXXXXXXXXXXXXX'

from_address = 'XXXXXXXXXXXXXXXXXXXX@qq.com' # 发送人的地址

password = 'XXXXXXXXXXXXXXXXXXXX' # 邮箱密码换成他提供的16位授权码

to_address = 'XXXXXXXXXXXXXXXXXXXX@qq.com' # 收件人地址,可以是多个的

smtp_server = 'smtp.qq.com' # 因为我是使用QQ邮箱..

class AutoArchive(object):

"""自动打包并上传到蒲公英,发邮件通知"""

def __init__(self):

pass

def clean(self):

print("\n\n===========开始clean操作===========")

start = time.time()

clean_command = 'xcodebuild clean -workspace %s/%s.xcworkspace -scheme %s -configuration Release' % (

archive_workspace_path, project_name, project_name)

clean_command_run = subprocess.Popen(clean_command, shell=True)

clean_command_run.wait()

end = time.time()

# Code码

clean_result_code = clean_command_run.returncode

if clean_result_code != 0:

print("=======clean失败,用时:%.2f秒=======" % (end - start))

else:

print("=======clean成功,用时:%.2f秒=======" % (end - start))

self.archive()

def archive(self):

print("\n\n===========开始archive操作===========")

# 删除之前的文件

subprocess.call(['rm', '-rf', '%s/%s' % (archive_workspace_path, export_directory)])

time.sleep(1)

# 创建文件夹存放打包文件

subprocess.call(['mkdir', '-p', '%s/%s' % (archive_workspace_path, export_directory)])

time.sleep(1)

start = time.time()

archive_command = 'xcodebuild archive -workspace %s/%s.xcworkspace -scheme %s -configuration Release -archivePath %s/%s' % (

archive_workspace_path, project_name, project_name, archive_workspace_path, export_directory)

archive_command_run = subprocess.Popen(archive_command, shell=True)

archive_command_run.wait()

end = time.time()

# Code码

archive_result_code = archive_command_run.returncode

if archive_result_code != 0:

print("=======archive失败,用时:%.2f秒=======" % (end - start))

else:

print("=======archive成功,用时:%.2f秒=======" % (end - start))

# 导出IPA

self.export()

def export(self):

print("\n\n===========开始export操作===========")

print("\n\n==========请你耐心等待一会~===========")

start = time.time()

# export_command = 'xcodebuild -exportArchive -archivePath /Users/liangk/Desktop/TestArchive/myArchivePath.xcarchive -exportPath /Users/liangk/Desktop/TestArchive/out -exportOptionsPlist /Users/liangk/Desktop/TestArchive/ExportOptions.plist'

export_command = 'xcodebuild -exportArchive -archivePath %s/%s.xcarchive -exportPath %s/%s -exportOptionsPlist %s/ExportOptions.plist' % (

archive_workspace_path, export_directory, archive_workspace_path, export_directory, archive_workspace_path)

export_command_run = subprocess.Popen(export_command, shell=True)

export_command_run.wait()

end = time.time()

# Code码

export_result_code = export_command_run.returncode

if export_result_code != 0:

print("=======导出IPA失败,用时:%.2f秒=======" % (end - start))

else:

print("=======导出IPA成功,用时:%.2f秒=======" % (end - start))

# 删除archive.xcarchive文件

subprocess.call(['rm', '-rf', '%s/%s.xcarchive' % (archive_workspace_path, export_directory)])

self.upload('%s/%s/%s.ipa' % (archive_workspace_path, export_directory, project_name))

def upload(self, ipa_path):

print("\n\n===========开始上传蒲公英操作===========")

if ipa_path:

# https://www.pgyer.com/doc/api 具体参数大家可以进去里面查看,

url = 'http://www.pgyer.com/apiv1/app/upload'

data = {

'uKey': USER_KEY,

'_api_key': API_KEY,

'installType': '1',

'updateDescription': description

}

files = {'file': open(ipa_path, 'rb')}

r = requests.post(url, data=data, files=files)

if r.status_code == 200:

# 是否需要打开浏览器

# self.open_browser(self)

self.send_email()

else:

print("\n\n===========没有找到对应的ipa===========")

return

@staticmethod

def open_browser(self):

webbrowser.open(ipa_download_url, new=1, autoraise=True)

@staticmethod

def _format_address(self, s):

name, address = parseaddr(s)

return formataddr((Header(name, 'utf-8').encode(), address))

def send_email(self):

# https://www.pgyer.com/XXX app地址

# 只是单纯的发了一个文本邮箱,具体的发附件和图片大家可以自己去补充

msg = MIMEText('

Hello

' +

'

╮(╯_╰)╭应用已更新,请下载测试╮(╯_╰)╭

' +

'

蒲公英的更新会有延迟,具体版本时间以邮件时间为准

' +

'', 'html', 'utf-8')

msg['From'] = self._format_address(self, 'iOS开发团队 ' % from_address)

msg['Subject'] = Header('来自iOS开发团队的问候……', 'utf-8').encode()

server = smtplib.SMTP(smtp_server, 25) # SMTP协议默认端口是25

server.set_debuglevel(1)

server.login(from_address, password)

server.sendmail(from_address, [to_address], msg.as_string())

server.quit()

print("===========邮件发送成功===========")

if __name__ == '__main__':

description = input("请输入内容:")

archive = AutoArchive()

archive.clean()

关于ExportOptions.plist文件

因为 Xcode 9+ 默认不允许访问钥匙串的内容,必须要设置 allowProvisioningUpdates 才会允许,Python的Xcode插件目前无法支持此项完成打包流程。

解决步骤如下:

1、手动Xcode10打包,导出ExportOptions.plist文件;

2、编辑ExportOptions.plist文件,配置 provisioningProfiles 对应填入Bundle identifier及证书关联配置文件(打包时自动匹配或手动填入证书,provisioningProfiles需配置的必填信息可自动生成);

3、提供ExportOptions.plist文件路径供Python脚本调用(详请参看Python脚本代码)。

具体的内容

compileBitcode//是否编译bitcode

method

ad-hoc/

provisioningProfiles

文件bundle id

Adhoc_ID

signingCertificate//证书签名

这里填证书签名

signingStyle

manual

stripSwiftSymbols

teamID

AANCCUK4M3//TeamID

thinning

分析

xcodebuild archive -workspace XXX.xcworkspace -scheme XXX -configuration Release -archivePath XXX CONFIGURATION_BUILD_DIR ./dir ODE_SIGN_IDENTITY=证书 PROVISIONING_PROFILE=描述文件UUID

文件

说明

-workspace XXX.xcworkspace

XXX.xcworkspace需要编译工程的工作空间名称,如果工程不是.xcworkspace的,可以不需要-workspace XXX.xcworkspace这段话

-scheme XXX

XXX是工程名称,-scheme XXX是指定构建工程的名称

-configuration Release

填入打包的方式是Debug或Release,就跟在Xcode中编译前需要在Edit scheme的Build configuration中选择打出来的包是Debug还是Release包一样,-configuration就是配置编译的Build configuration

-archivePath XXX

配置生成.xcarchive的路径,

ODE_SIGN_IDENTITY=证书

配置打包的指定证书,如果该工程的Xcode已经配置好了证书,那么不加入这段话也可以,打包出来的证书就是Xcode中配置好的。

PROVISIONING_PROFILE=描述文件UUID

配置打包的描述文件,同上,Xcode已经配置好了就不用在填入这段话了

CONFIGURATION_BUILD_DIR

配置编译文件的输出路径,如果需要用到.xcarchive文件内部的dSYM等文件,可以使用改字段指定输出路径。

问题一

配置一下compileBicode=NO即可

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对w3xue的支持。

python项目打包部署到ios_Python的iOS自动化打包实例代码相关推荐

  1. python123 ios_Python的iOS自动化打包实例代码

    Hello ' + ' ╮(╯_╰)╭应用已更新,请下载测试╮(╯_╰)╭ ' + ' 蒲公英的更新会有延迟,具体版本时间以邮件时间为准 ' + '

  2. xcode 选择configuraftions 打包_分利宝IOS自动化打包

    前言 在iOS开发中,我们常用的打包上传方式就是用Xcode的archive方式打包.到了测试阶段,需要频繁的打包提交到测试平台,整个流程包括:编译-打包-上传,整个过程需要我们去坚守每一步操作,提交 ...

  3. iOS自动化打包之重签名导出不同证书ipa探索

    在完成基础的自动包打包流程过后, 随即也出现了日常中常见的问题, 比如我们每次需要打出不同网络环境和不同证书的ipa, 由于开发者可以添加的设备只有100个, 而公司的几个项目都是用的一个账号, 各项 ...

  4. iOS自动化打包发布之fastlane 实现 发布AppStore 蒲公英

    iOS自动化打包发布之fastlane 实现 fastlane官方文档 前提插件配置 首先要安装xcode-select 然后安装fastlane sudo gem install fastlane ...

  5. ios自动化打包 替换icon 启动图 bid appname 额外资源

    ios自动化打包脚本 下载地址https://github.com/gwh111/package 打开后自行替换 icon 启动图 bid appname 额外资源 原理:最新的脚本还是一个个替换后再 ...

  6. python资料百度网盘-python自动保存百度盘资源到百度盘中的实例代码

    本实例的实现逻辑是,应用selenium UI自动化登录百度盘,读取存储百度分享地址和提取码的txt文档,打开百度盘分享地址,填入提取码,然后保存到指定的目录中 全部代码如下: # -*-coding ...

  7. python项目打包部署到ios_Python iOS 自动打包脚本(包含上传到fir)

    Python iOS自动打包脚本 使用说明 1.1 使用python3编写,没有python3 环境的需要下载python3 python官网下载 1.2 通过Homebrew安装Python3 1. ...

  8. IOS自动化打包介绍

    摘要 随着苹果手持设备用户的不断增加,ios应用也增长迅速,同时随着iphone被越狱越来越多的app 的渠道也不断增多,为各个渠道打包成了一件费时费力的工作,本文提供一种比较智能的打包方式来减少其带 ...

  9. Python项目可以有多大?最多可以有多少行代码?

    全世界有3.14 % 的人已经关注了 数据与算法之美 导读:总是看到有人说,动态一时爽,重构火葬场.然而这世界上有的是著名的开源项目, 也有像 Github.Instagram 这样流量巨大的知名网站 ...

最新文章

  1. ui培训教程分享:平面设计怎样视觉空间感?
  2. HDU 5816 Hearthstone
  3. 剑鱼行动(普里姆算法)
  4. FCN训练自己的数据集及测试
  5. android切换到上个页面,Android 返回上一个界面刷新数据
  6. 基于Spring Boot的WebSocket应用程序并捕获HTTP会话ID
  7. FreeWheel是一家怎样的公司?| 人物志
  8. Activity 生命周期与状态保存
  9. 关于 JQuery 的克隆
  10. python继承中的参数_python 继承中的super
  11. 软件测试-微信红包测试点
  12. c语言罗盘,风水罗盘下载_风水罗盘手机免费最新版v1.0下载_hycdc游戏网
  13. Matlab 曲线拟合之 polyfit 、polyval、poly2str 函数
  14. vector函数用法
  15. 【魔兽世界插件】魔兽世界插件实战笔记从入门到放弃的心理历程 第三节-窗体颜色设置与渐变
  16. 【离散数学】第二章 笔记(完)
  17. java七牛云图片压缩_七牛云 CDN 历史图片批量压缩
  18. echarts x 起始_echarts实现获取datazoom的起始值(包括x轴和y轴)
  19. python写手机应用宝下载_APK 批量爬取脚本(应用宝和360市场)
  20. python二级考试题详解

热门文章

  1. No slave process to process jobs, aborting 报错!!!
  2. 熟悉java环境实验报告_2018-2019-2 20175324实验二面向对象程序设计《Java开发环境的熟悉》实验报告...
  3. python自动点击网页按钮_Python+Selenium使用(二)- 自动点击下一页
  4. 有效使用计算机操作系统,有效地使用计算机操作系统.doc
  5. python的线性链表_Python线性表——单链表-阿里云开发者社区
  6. python基本输入与格式化_Python导学基础(三)输入、格式化输出、基本运算符
  7. Meerkat放弃直播视频社交业务
  8. 万方数据知识平台 TFHpple +Xpath解析
  9. maven远程发布jar
  10. easyui combobox默认选中项