乐趣区

关于python:利用Python开发App实战

我很早之前就想开发一款 app 玩玩,无奈对 java 不够相熟,之前也没有开发 app 的教训,因而始终耽误了。最近想到尝试用 python 开发一款 app,google 搜寻了一番后,发现的确有路可寻,目前也有了一些绝对成熟的模块,于是便开始了入手实战,过程中发现这其中有很多坑,好在最终依附 google 解决了,因而小记一番。

说在后面的话

python 语言尽管很万能,但用它来开发 app 还是显得有点不对路,因而用 python 开发的 app 该当是作为编码练习、或者自娱自乐所用,加上目前这方面的模块还不是特地成熟,bug 比拟多,总而言之,劝君莫轻入。

筹备工作

利用 python 开发 app 须要用到 python 的一个模块–kivy,kivy 是一个开源的,跨平台的 Python 开发框架,用于开发应用翻新的应用程序。简而言之,这是一个 python 桌面程序开发框架(相似 wxpython 等模块),弱小的是 kivy 反对 linux、mac、windows、android、ios 平台,这也是为什么开发 app 须要用到这个模块。

尽管 kivy 是跨平台的,然而想要在不同的平台应用 python 代码,还须要将 python 代码打包成对应平台的可执行程序,好在 kivy 我的项目下有个打包工具我的项目–buildozer,这是官网举荐的打包工具,因为绝对比较简单,自动化水平高,其余我的项目比方:python-for-android 也能起到相似的作用,这里不开展介绍。

搭建 kivy 开发环境

须要在 pc 上装置 kivy 开发环境,这里演示下 mac 与 linux 下的装置过程。

install kivy for mac

装置一些依赖包:

brew install pkg-config sdl2 sdl2_image sdl2_ttf sdl2_mixer gstreamer 

装置 cython 以及 kivy:

pip install cython==0.25
pip install kivy 

如果装置 kivy 报错,则应用上面的形式装置 kivy:

git clone https://github.com/kivy/kivy
python setup.py install 

装置后测试:

$python
Python 2.7.10 (default, Jul 15 2017, 17:16:57)
[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.31)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>>
>>> import kivy
[INFO] [Logger] Record log in /Users/didi/.kivy/logs/kivy_18-05-08_4.txt
[INFO] [Kivy] v1.10.1.dev0, git-5f6c66e, 20180507
[INFO] [Python] v2.7.10 (default, Jul 15 2017, 17:16:57)
[GCC 4.2.1 Compatible Apple LLVM 9.0.0 (clang-900.0.31)] 

阐明:导入 kivy 模块没有报错则阐明装置胜利。

install kivy for centos7

先装置依赖:

yum install 
make 
mercurial 
automake 
gcc 
gcc-c++ 
SDL_ttf-devel 
SDL_mixer-devel 
khrplatform-devel 
mesa-libGLES 
mesa-libGLES-devel 
gstreamer-plugins-good 
gstreamer 
gstreamer-python 
mtdev-devel 
python-devel 
python-pip 
java-devel 

装置 cython 以及 kivy:

pip install Cython==0.20
pip install kivy 

centos 装置 kivy 参考:https://kivy.org/docs/install…

阐明:其余装置 kivy 形式可移步:https://kivy.org/#download(须要翻墙)

用 kivy 开发第一个 python app

装置完 kivy 就能够开发 app 程序了,这里演示下 hello-world 程序,对于 kivy 更简单的用法不是本文重点,前面再成文介绍。

  1. 创立一个 main.py 文件,写入:
#! -*- coding:utf-8 -*-
from kivy.app import App
class HelloApp(App):
pass
if __name__ == '__main__':
HelloApp().run() 

2) 创立一个 hello.kv 文件,写入:

Label:
text: 'Hello, World! I am nMask' 

简略阐明:main.py 是入口函数,定义了一个 HelloApp 类,该类继承 kivy.app;hello.kv 文件是 kivy 程序,相当于定义界面风格等,该文件命名规定为类名小写且去除 app。

运行第一个 python app

python main.py 

运行后果:

装置 buildozer 工具

通过以上的编码,我创立了本人的第一个 python app 程序,该程序能够间接在 mac、linux、windows 平台下运行,那么如何让它在安卓或者苹果手机上运行呢?咱们晓得在安卓上运行,须要将其打包成 apk 安装程序,因而就须要用到后面提到过的 buildozer 工具,(buildozer 工具能够打包 kivy 程序,反对 android、ios 等),buildozer 的装置过程比较简单:

pip install buildozer 

应用 buildozer 工具将 kivy 程序打包成 apk

在 python 我的项目目录下运行:

buildozer init 

运行胜利将会创立一个配置文件 buildozer.spec,能够通过批改配置文件更改 app 的名称等,而后运行:

buildozer android debug deploy run 

运行以上命令将会生成跨平台的安装包,可实用安卓、ios 等,如果用于安卓,则是利用 python-for-android 我的项目。

在第一次运行以上命令的时候,会主动在零碎中下载安卓 sdk 等必要文件,如下图。(过程须要翻墙,而且有很多依赖须要下载)

阐明:这里只演示打包成 apk 文件,iso 平台的可自行钻研,参考文档:https://github.com/kivy/build…。

python apk 程序测试

如果以上步骤都运行胜利的话,应该会在我的项目目录下的 bin 目录下生成一个 apk 文件,相似如下:

而后将 apk 下载到安卓零碎的手机上,装置即可,测试成果如下:

关上 app

buildozer 应用阐明

Usage:
buildozer [--profile <name>] [--verbose] [target] <command>...
buildozer --version
Available targets:
android        Android target, based on python-for-android project
ios            iOS target, based on kivy-ios project
android_old    Android target, based on python-for-android project (old toolchain)
Global commands (without target):
distclean          Clean the whole Buildozer environment.
help               Show the Buildozer help.
init               Create a initial buildozer.spec in the current directory
serve              Serve the bin directory via SimpleHTTPServer
setdefault         Set the default command to run when no arguments are given
version            Show the Buildozer version
Target commands:
clean      Clean the target environment
update     Update the target dependencies
debug      Build the application in debug mode
release    Build the application in release mode
deploy     Deploy the application on the device
run        Run the application on the device
serve      Serve the bin directory via SimpleHTTPServer
Target "android_old" commands:
adb                Run adb from the Android SDK. Args must come after --, or
use --alias to make an alias
logcat             Show the log from the device
Target "ios" commands:
list_identities    List the available identities to use for signing.
xcode              Open the xcode project.
Target "android" commands:
adb                Run adb from the Android SDK. Args must come after --, or
use --alias to make an alias
logcat             Show the log from the device
p4a                Run p4a commands. Args must come after --, or use --alias
to make an alias 

buildozer 打包过程中的坑点

如果在打包过程中遇到报错,能够批改 buildozer.spec 配置文件中的 log_level 为 2,而后从新运行,能够看具体的错误信息。

报错:You might have missed to install 32bits libs

这个错是我在 centos7 上运行时报的错,粗心是零碎短少了某些 32 位的依赖文件。
解决方案:

yum -y install --skip-broken glibc.i686 arts.i686 audiofile.i686 bzip2-libs.i686 cairo.i686 cyrus-sasl-lib.i686 dbus-libs.i686 directfb.i686 esound-libs.i686 fltk.i686 freeglut.i686 gtk2.i686 hal-libs.i686 imlib.i686 lcms-libs.i686 lesstif.i686 libacl.i686 libao.i686 libattr.i686 libcap.i686 libdrm.i686 libexif.i686 libgnomecanvas.i686 libICE.i686 libieee1284.i686 libsigc++20.i686 libSM.i686 libtool-ltdl.i686 libusb.i686 libwmf.i686 libwmf-lite.i686 libX11.i686 libXau.i686 libXaw.i686 libXcomposite.i686 libXdamage.i686 libXdmcp.i686 libXext.i686 libXfixes.i686 libxkbfile.i686 libxml2.i686 libXmu.i686 libXp.i686 libXpm.i686 libXScrnSaver.i686 libxslt.i686 libXt.i686 libXtst.i686 libXv.i686 libXxf86vm.i686 lzo.i686 mesa-libGL.i686 mesa-libGLU.i686 nas-libs.i686 nss_ldap.i686 cdk.i686 openldap.i686 pam.i686 popt.i686 pulseaudio-libs.i686 sane-backends-libs-gphoto2.i686 sane-backends-libs.i686 SDL.i686 svgalib.i686 unixODBC.i686 zlib.i686 compat-expat1.i686 compat-libstdc++-33.i686 openal-soft.i686 alsa-oss-libs.i686 redhat-lsb.i686 alsa-plugins-pulseaudio.i686 alsa-plugins-oss.i686 alsa-lib.i686 nspluginwrapper.i686 libXv.i686 libXScrnSaver.i686 qt.i686 qt-x11.i686 pulseaudio-libs.i686 pulseaudio-libs-glib2.i686 alsa-plugins-pulseaudio.i686 python-matplotli 

参考:https://ask.fedoraproject.org…

报错:Error compiling Cython file

谬误粗心为 cython 文件出错,可能是 cython 模块没有装置,或者版本有问题。
解决方案:

pip install cython==0.25 

报错:IOError: [Errno 2] No such file or directory……

这是在打包的最初一步,将 apk 文件 copy 到我的项目 bin 目录下时报的错,是 buildozer 的一个 bug。

解决方案:

批改 /usr/local/lib/python2.7/dist-packages/buildozer/tagets/android.py 文件:

(1) 在文件结尾导入:

from distutils.version import LooseVersion 

(2) 将 786 行:XXX found how the apk name is really built from the title 这一行以下的代码替换为:

__sdk_dir = self.android_sdk_dir
build_tools_versions = os.listdir(join(__sdk_dir, 'build-tools'))
build_tools_versions = sorted(build_tools_versions, key=LooseVersion)
build_tools_version = build_tools_versions[-1]
gradle_files = ["build.gradle", "gradle", "gradlew"]
is_gradle_build = any((exists(join(dist_dir, x)) for x in gradle_files)) and build_tools_version >=’25.0' 

buildozer 虚拟机

kivy 官网推出了一个 buildozer 虚拟机镜像,曾经装置好了 buildozer 以及一些依赖文件,为 buildozer 打包测试提供平台。因为之前我在 mac 上利用 buildozer 打包始终报错,起初换成 centos 也仍然没有胜利,因而便下载了此虚拟机,测试成果如下:

虚拟机下载地址:http://txzone.net/files/torre…

阐明:对于无奈解决依赖问题的敌人,能够应用此虚拟机进行程序打包,开发环境还是举荐用本人的本机。

kivy 开发实例

因为本文重点在于介绍如何利用 kivy+buildozer 开发一款 python app,因而对于 kivy 的开发过程,以及 app 性能进行了最简化。想要学习如何开发更简单的 app,可参考:https://muxuezi.github.io/pos…

起源:https://blog.csdn.net/nmask

欢送关注我的微信公众号「码农解围」,分享 Python、Java、大数据、机器学习、人工智能等技术,关注码农技术晋升•职场解围•思维跃迁,20 万 + 码农成长充电第一站,陪有幻想的你一起成长

退出移动版