Rumah >pembangunan bahagian belakang >Tutorial Python >Pembangunan aplikasi praktikal menggunakan Python

Pembangunan aplikasi praktikal menggunakan Python

WBOY
WBOYke hadapan
2023-04-11 20:43:161645semak imbas

Pembangunan aplikasi praktikal menggunakan Python

Walaupun bahasa Python sangat serba boleh, masih agak salah untuk menggunakannya untuk membangunkan aplikasi Oleh itu, aplikasi yang dibangunkan dengan Python harus digunakan sebagai latihan pengekodan atau untuk hiburan diri .

Persediaan

Menggunakan Python untuk membangunkan apl memerlukan penggunaan modul Python – kivy ialah rangka kerja pembangunan Python merentas platform untuk Penggunaan pembangunan aplikasi inovatif. Ringkasnya, ini ialah rangka kerja pembangunan program desktop Python (serupa dengan wxpython dan modul lain yang penting ialah kivy menyokong platform linux, mac, windows, android dan ios. Inilah sebabnya mengapa modul ini diperlukan untuk membangunkan aplikasi.

Walaupun kivy adalah platform silang, jika anda ingin menggunakan kod Python pada platform yang berbeza, anda juga perlu membungkus kod Python ke dalam program boleh laku untuk platform yang sepadan. Nasib baik, terdapat pembungkusan alat di bawah projek kivy Project – buildozer, ini adalah alat pembungkusan yang disyorkan secara rasmi kerana ia agak mudah dan mempunyai tahap automasi yang tinggi Projek lain seperti Python-untuk-android juga boleh memainkan peranan yang sama dan tidak akan diperkenalkan di sini .

Membina persekitaran pembangunan kivy

Anda perlu memasang persekitaran pembangunan kivy pada PC anda. Berikut ialah demonstrasi proses pemasangan di bawah mac dan linux.

install kivy for mac

Pasang beberapa pakej bergantung:

brew install pkg-config sdl2 sdl2_image sdl2_ttf sdl2_mixer gstreamer

Pasang cython dan kivy:

pip install cython==0.25
pip install kivy

Jika ralat berlaku semasa memasang kivy , gunakan Pasang kivy dengan cara berikut:

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

Ujian selepas pemasangan:

$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)]

Nota: Jika tiada ralat semasa mengimport modul kivy, pemasangan berjaya.

pasang kivy untuk centos7

Pergantungan pemasangan pertama:

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

Pasang cython dan kivy:

pip install Cython==0.20
pip install kivy

centos Rujukan untuk memasang kivy: https://kivy.org/docs/installation/installation-linux.html#using-software-packages

Nota: Cara lain untuk memasang kivy boleh didapati di: https :// kivy.org/#download (perlu memintas tembok api)

Bangunkan apl Python pertama dengan kivy

Selepas memasang kivy, anda boleh membangunkan apl Berikut ialah demonstrasi Program hello-world, penggunaan kivy yang lebih kompleks bukanlah fokus artikel ini, dan akan diperkenalkan secara bertulis kemudian.

Buat fail main.py dan tulis:

#! -*- coding:utf-8 -*-
from kivy.app import App
class HelloApp(App):
pass
if __name__ == '__main__':
HelloApp().run()

Buat fail hello.kv dan tulis:

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

Penjelasan ringkas: main.py ialah fungsi kemasukan, yang mentakrifkan kelas HelloApp, yang mewarisi kivy.app fail hello.kv ialah program kivy, yang bersamaan dengan mentakrifkan gaya antara muka, dsb. Peraturan penamaan ini; fail ialah nama kelas dalam huruf kecil dan Alih keluar aplikasi.

Jalankan apl Python pertama

python main.py

Hasil berjalan:

Pembangunan aplikasi praktikal menggunakan Python

Pasang Alat buildozer

Melalui pengekodan di atas, saya telah mencipta program aplikasi python saya yang pertama tentang berjalan di atasnya? Kami tahu bahawa untuk berjalan pada Android, ia perlu dibungkus ke dalam program pemasangan apk, jadi kami perlu menggunakan alat buildozer yang dinyatakan sebelum ini (Alat buildozer boleh membungkus program kivy dan menyokong pemasangan android, ios, dll.). proses buildozer adalah agak mudah. 🎜>

pip install buildozer
Operasi yang berjaya akan mencipta fail konfigurasi buildozer.spec Anda boleh menukar nama apl dengan mengubah suai fail konfigurasi, dan kemudian jalankan:


<.>Menjalankan arahan di atas akan menghasilkan pakej pemasangan merentas platform Ia boleh digunakan pada Android, ios, dll. Jika ia digunakan untuk Android, gunakan projek python-for-android.


Apabila anda menjalankan perintah di atas buat kali pertama, Android sdk dan fail lain yang diperlukan akan dimuat turun secara automatik dalam sistem, seperti yang ditunjukkan di bawah. (Proses ini memerlukan memintas dinding, dan terdapat banyak kebergantungan yang perlu dimuat turun)
buildozer init


buildozer android debug deploy run

Nota: Di sini kami hanya menunjukkan pembungkusan ke dalam fail apk Jika anda sedang menggunakan platform iso, anda boleh mengkajinya sendiri Sila rujuk dokumentasi : https://github.com/kivy/buildozer.

ujian program apk python

Jika langkah di atas berjaya dilaksanakan, fail apk harus dijana dalam direktori bin di bawah direktori projek, sama seperti yang berikut: Pembangunan aplikasi praktikal menggunakan Python


Kemudian muat turun apk ke telefon Android anda dan pasangkannya seperti berikut:


<.>

Buka apl

Pembangunan aplikasi praktikal menggunakan Python

Pembangunan aplikasi praktikal menggunakan Python

buildozer使用说明

Usage:
buildozer [--profile <name>] [--verbose] [target] <command>...
buildozer --version
Available targets:
androidAndroid target, based on python-for-android project
iosiOS target, based on kivy-ios project
android_oldAndroid target, based on python-for-android project (old toolchain)
Global commands (without target):
distcleanClean the whole Buildozer environment.
help Show the Buildozer help.
init Create a initial buildozer.spec in the current directory
serveServe the bin directory via SimpleHTTPServer
setdefault Set the default command to run when no arguments are given
versionShow the Buildozer version
Target commands:
cleanClean the target environment
update Update the target dependencies
debugBuild the application in debug mode
releaseBuild the application in release mode
deploy Deploy the application on the device
runRun the application on the device
serveServe the bin directory via SimpleHTTPServer
Target "android_old" commands:
adbRun 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_identitiesList the available identities to use for signing.
xcodeOpen the xcode project.
Target "android" commands:
adbRun adb from the Android SDK. Args must come after --, or
use --alias to make an alias
logcat Show the log from the device
p4aRun 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/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文件:

在文件开头导入:

from distutils.version import LooseVersion

将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也依然没有成功,因此便下载了此虚拟机,测试效果如下:

Pembangunan aplikasi praktikal menggunakan Python

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

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

kivy开发实例

因为本文重点在于介绍如何利用kivy+buildozer开发一款python app,因此对于kivy的开发过程,以及app功能进行了最简化。

Atas ialah kandungan terperinci Pembangunan aplikasi praktikal menggunakan Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:51cto.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam