• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

利用Python开发App,来一起看看他是怎么做的。

python 搞java代码 3年前 (2022-05-21) 30次浏览 已收录 0个评论

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理

本文来自腾讯云,作者:Python小二

最近想到尝试用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 <span>for</span> mac

www#gaodaima.com来源gaodaimacom搞#^代%!码&网搞代码

 

安装一些依赖包:

brew install pkg-config sdl2 sdl2_image sdl2_ttf sdl2_mixer gstreamer

 

安装cython以及kivy:

pip install cython==0.25<span>
pip install kivy</span>

 

如果安装kivy报错,则使用下面的方式安装kivy:

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

 

安装后测试:

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

 

说明:导入kivy模块没有报错则说明安装成功。

install kivy <span>for</span> centos7

 

先安装依赖:

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

 

安装cython以及kivy:

pip install Cython==0.20<span>
pip install kivy</span>

 

centos安装kivy参考:https://kivy.org/docs/installation/installation-linux.html#using-software-packages

说明:其他安装kivy方式可移步:https://kivy.org/#download(需要翻墙)

用kivy开发第一个python app

安装完kivy就可以开发app程序了,这里演示下hello-world程序,关于kivy更复杂的用法不是本文重点,后面再成文介绍。

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

 

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

<span>Label:
text: </span><span>"</span><span>Hello, World! I am nMask</span><span>"</span>

 

简单说明: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/buildozer。

python apk程序测试

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

然后将apk下载到安卓系统的手机上,安装即可,测试效果如下:

打开app

buildozer使用说明

<span>Usage:
buildozer [</span>--profile <name>] [--verbose] [target] <command><span>...
buildozer </span>--<span>version
Available targets:
android        Android target, based on python</span>-<span>for</span>-<span>android project
ios            iOS target, based on kivy</span>-<span>ios project
android_old    Android target, based on python</span>-<span>for</span>-<span>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 </span><span>in</span><span> 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 </span><span>in</span><span> debug mode
release    Build the application </span><span>in</span><span> release mode
deploy     Deploy the application on the device
run        Run the application on the device
serve      Serve the bin directory via SimpleHTTPServer
Target </span><span>"</span><span>android_old</span><span>"</span><span> commands:
adb                Run adb </span><span>from</span> the Android SDK. Args must come after --, <span>or</span><span>
use </span>--<span>alias to make an alias
logcat             Show the log </span><span>from</span><span> the device
Target </span><span>"</span><span>ios</span><span>"</span><span> commands:
list_identities    List the available identities to use </span><span>for</span><span> signing.
xcode              Open the xcode project.
Target </span><span>"</span><span>android</span><span>"</span><span> commands:
adb                Run adb </span><span>from</span> the Android SDK. Args must come after --, <span>or</span><span>
use </span>--<span>alias to make an alias
logcat             Show the log </span><span>from</span><span> the device
p4a                Run p4a commands. Args must come after </span>--, <span>or</span> use --<span>alias
to make an alias</span>

 

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
<code class="prism language-python"></code>

参考:https://ask.fedoraproject.org/en/question/9556/how-do-i-install-32bit-libraries-on-a-64-bit-fedora/

报错: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)在文件开头导入:

<span>from</span> distutils.version <span>import</span> LooseVersion

 

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

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

 

buildozer虚拟机

kivy官方推出了一个buildozer虚拟机镜像,已经安装好了buildozer以及一些依赖文件,为buildozer打包测试提供平台。由于之前我在mac上利用buildozer打包一直报错,后来换成centos也依然没有成功,因此便下载了此虚拟机,测试效果如下:

虚拟机下载地址:http://txzone.net/files/torrents/kivy-buildozer-vm-2.0.zip

说明:对于无法解决依赖问题的朋友,可以使用此虚拟机进行程序打包,开发环境还是推荐用自己的本机。

kivy开发实例

因为本文重点在于介绍如何利用kivy+buildozer开发一款python app,因此对于kivy的开发过程,以及app功能进行了最简化。想要学习如何开发更复杂的app,可参考:https://muxuezi.github.io/posts/kivy-perface.html#


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:利用Python开发App,来一起看看他是怎么做的。

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址