Zum Inhalt springen

Python: Unterschied zwischen den Versionen

Aus wiki.archlinux.de
 
(9 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 7: Zeile 7:
Python 2 wurde im September 2022 aus den offiziellen Repositorien entfernt, da es inzwischen nicht mehr supportet wird und auch keinerlei Updates oder Sicherheitspatches erhält. Sofern notwendig, kann man {{AUR|python2}} aber noch aus dem AUR installieren.
Python 2 wurde im September 2022 aus den offiziellen Repositorien entfernt, da es inzwischen nicht mehr supportet wird und auch keinerlei Updates oder Sicherheitspatches erhält. Sofern notwendig, kann man {{AUR|python2}} aber noch aus dem AUR installieren.


== Besonderheiten bezüglich Python 2 ==
== Weitere Implementierungen (Auswahl) ==
Aufgrund der Tatsache, dass Python 3 teilweise nicht mehr zu älteren Versionen von Python kompatibel ist, kann es notwendig sein, beide Versionen parallel zu betreiben. Dies ist problemlos möglich, da {{ic|python2}} unter diesem Namen eine eigenständige Installation ist, und {{ic|python}} (3.x) nicht beeinflusst.
 
Wenn man eigene Programme entwickelt, sollte man nach Möglichkeit Python 3.x verwenden, und nur, wenn man spezielle Funktionen oder Module von Python 2.x nutzen muss, auf Python 2.x zurückfallen.
 
Der Umstand, dass unter Arch Python 2 als {{ic|/usr/bin/python2}}, und nicht als {{ic|/usr/bin/python}} vorhanden ist, kann dafür sorgen, dass Arch-fremde Scripte, oder Programme nicht funktionieren. In einem solchen Fall müssen sie explizit mit der richtigen Python-Version aufgerufen werden ({{ic|python2 script.py}} oder {{ic|python script.py}}), oder das Shebang in der Datei angepasst werden ({{ic|#!/usr/bin/python3}} wird zu {{ic|#!/usr/bin/python}}, oder {{ic|#!/usr/bin/python}} wird zu {{ic|#!/usr/bin/python2}}).
 
=== Python-Version abfragen ===
 
Ein einfacher Weg, die aktuelle Python-Version in eigenen Programmen abzufragen und entsprechend zu reagieren ist folgender Code-Schnipsel.
 
import sys
if not sys.version_info >= (3,3,0):
    print('Bitte mindestens Python 3.3 verwenden!')
 
Dies Prüft auf Python 3.3.0 (oder neuer). Hier kann auch etwas allgemeiner {{ic|(3,0)}} angegeben werden, um generell Python 3 zu erfordern. Mittels des Vergleichsoperators (hier {{ic|1=>=}}) kann zudem bestimmt werden, welche Bedingung erfüllt sein muss. Wenn exakt eine Version genutzt werden soll, kann als Operand {{ic|(3,3,0,'final',0)}} verwendet werden. Dies ist allerdings nicht empfehlenswert, im Regelfall reicht {{ic|1=>= (3,0)}} aus.
 
Anstelle des {{ic|print()}} könnte man hier nun weitergehen, und die genaue Version abfragen, und je nach Version entweder eine {{ic|Exception}} generieren, oder Parameter verändern, so dass das Programm Dinge anders ausführt. Es empfiehlt sich, dies möglichst früh im Programmablauf einzubauen.
 
== Weitere Implementierungen ==
Neben der standardmäßig vorhandenen Implementierung ''CPython'' gibt es noch einige weitere Implementierungen.
Neben der standardmäßig vorhandenen Implementierung ''CPython'' gibt es noch einige weitere Implementierungen.


* '''PyPy''': Ein in Python geschriebener Python-Interpreter – {{ic|extra/pypy}}
{| class="wikitable sortable"
* '''Parrot''': Virtuelle Maschine für Programmiersprachen – {{ic|extra/parrot}}
! Name !! Sprache !! Paket
* '''Jython''': In Java für die JVM geschriebene Implementation – {{ic|extra/jython}}
|-
* '''IronPython''': Implementation für die .NET-Entwicklungsumgebung – {{ic|aur/ironpython-git}}
| PyPy || Python || {{Paket|pypy}}
* '''Stackless''': Experimentelle Implementation, die nicht den Prozessor-Stack nutzt – {{ic|aur/stackless-python}}
|-
| Jython || Java || {{Paket|jython}}
|-
| IronPython || .NET || {{AUR|ironpython-git}}
|}


Des Weiteren ist es auch möglich, Python als Interpreter für Webseiten zu verwenden. Der Artikel [[lighttpd]] wartet hierzu mit einem entsprechenden Einrichtungsbeispiel auf.
Des Weiteren ist es auch möglich, Python als Interpreter für Webseiten zu verwenden. Der Artikel [[lighttpd]] wartet hierzu mit einem entsprechenden Einrichtungsbeispiel auf.


== Einfache GUI-Programme erstellen ==
== GUI-Programme erstellen ==
Python verfügt mittels {{ic|tkinter}} über eine Schnitstelle zu {{Paket|Tk}}. Mittels Tk können sehr einfache grafische Programme erstellt werden. Damit tkinter benutzt werden kann, muss {{paket|tk}} installiert sein.
[[Datei:Python_tkinter_example.png|thumb|250px|Ein Tk-Programm, erstellt mittels tkinter zeigt einfaches Fenster an.]]
Python hat Schnittstellen zu diversen GUI-Toolkits, damit ist es relativ einfach, grafische Anwendungen zu erstellen.
 
=== Einfache Fenster mittels tkinter ===
Python verfügt mittels ''tkinter'' über eine Schnitstelle zu Tk. Mittels Tk können sehr einfache grafische Programme erstellt werden. Damit tkinter benutzt werden kann, muss {{Paket|Tk}} installiert sein.


{{hc|1=einfaches_fenster.py|2=
{{hc|1=einfaches_fenster.py|2=
#!/bin/env python
#!/usr/bin/python
import tkinter as tk
import tkinter as tk
root = tk.Tk()
root = tk.Tk()


# Fensterinhalte erstellen
# Fensterinhalte erstellen
label1 = tk.Label(root, text='Hallo, Wikibenutzer!')
label1 = tk.Label(root, text='Hallo, Wikibenutzer,')
label2 = tk.Label(root, text='Die ist ein Beispiel für ein Tk-Programm')
label2 = tk.Label(root, text='dies ist ein Beispiel für ein Tk-Programm.')
label3 = tk.Label(root, text='Es wird Python’s tkinter-Implementation genutzt.')
label3 = tk.Label(root, text='Es wird Pythons tkinter-Implementation genutzt.')
button = tk.Button(root, text='Fenster schließen', command=root.quit)
button = tk.Button(root, text='Fenster schließen', command=root.quit)


Zeile 58: Zeile 46:
button.pack()
button.pack()


# Fensdtertitel setzen und Main-Loop starten.
# Fenstertitel setzen und Main-Loop starten.
root.title('Beispiel für das Wiki')
root.title('Beispiel für das Wiki')
root.mainloop()
root.mainloop()
}}
}}


Das Script wird dann einfach mittels {{ic|./einfaches_fenster.py}} ausgeführt, und das Fenster dann angezeigt.
Das Script wird dann einfach mittels {{ic|./einfaches_fenster.py}} ausgeführt, und das Fenster durch das erstellte Programm dann angezeigt.
 
=== Andere Toolit-Schnittstellen (Auswahl) ===
{| class="wikitable sortable"
! Name !! Toolkit !! Paket !! Website
|-
| Kivy || OpenGL-Basierend || {{Paket|python-kivy}} || [https://kivy.org] {{sprache|en}}
|-
| PyGObject || GTK || {{Paket|python-gobject}} || [https://pygobject.readthedocs.io] {{sprache|en}}
|-
| PyQt || Qt5/6 || {{Paket|python-pyqt5}}/{{Paket|python-pyqt6}} || [https://riverbankcomputing.com/software/pyqt/intro] {{sprache|en}}
|-
| wxPython || wxWidgets || {{Paket|wxpython}} || [https://www.wxpython.org] {{sprache|en}}
|}


== Weblinks ==
== Weblinks ==

Aktuelle Version vom 4. Februar 2025, 16:57 Uhr

Python ist eine multiparadigmatische, interpretierte, höhere Programmiersprache, die neben der einfachen Erlernbarkeit einen großen Schwerpunkt in der guten Lesbarkeit der Programme setzt.

Installation

Python 3 ist als python in core verfügbar, und kann von dort mittels Pacman installiert werden.

pacman -S python

Nach der Installation ist die interaktive Shell über python zu starten, und der Interpreter befindet sich in /usr/bin/python.

Python 2 wurde im September 2022 aus den offiziellen Repositorien entfernt, da es inzwischen nicht mehr supportet wird und auch keinerlei Updates oder Sicherheitspatches erhält. Sofern notwendig, kann man python2AUR aber noch aus dem AUR installieren.

Weitere Implementierungen (Auswahl)

Neben der standardmäßig vorhandenen Implementierung CPython gibt es noch einige weitere Implementierungen.

Name Sprache Paket
PyPy Python pypy
Jython Java jython
IronPython .NET ironpython-gitAUR

Des Weiteren ist es auch möglich, Python als Interpreter für Webseiten zu verwenden. Der Artikel lighttpd wartet hierzu mit einem entsprechenden Einrichtungsbeispiel auf.

GUI-Programme erstellen

Ein Tk-Programm, erstellt mittels tkinter zeigt einfaches Fenster an.

Python hat Schnittstellen zu diversen GUI-Toolkits, damit ist es relativ einfach, grafische Anwendungen zu erstellen.

Einfache Fenster mittels tkinter

Python verfügt mittels tkinter über eine Schnitstelle zu Tk. Mittels Tk können sehr einfache grafische Programme erstellt werden. Damit tkinter benutzt werden kann, muss Tk installiert sein.

einfaches_fenster.py
#!/usr/bin/python
import tkinter as tk
root = tk.Tk()

# Fensterinhalte erstellen
label1 = tk.Label(root, text='Hallo, Wikibenutzer,')
label2 = tk.Label(root, text='dies ist ein Beispiel für ein Tk-Programm.')
label3 = tk.Label(root, text='Es wird Pythons tkinter-Implementation genutzt.')
button = tk.Button(root, text='Fenster schließen', command=root.quit)

# Fensterinhalte im Fenster anordnen (hier per pack() einfach untereinander)
label1.pack()
label2.pack()
label3.pack()
button.pack()

# Fenstertitel setzen und Main-Loop starten.
root.title('Beispiel für das Wiki')
root.mainloop()

Das Script wird dann einfach mittels ./einfaches_fenster.py ausgeführt, und das Fenster durch das erstellte Programm dann angezeigt.

Andere Toolit-Schnittstellen (Auswahl)

Name Toolkit Paket Website
Kivy OpenGL-Basierend python-kivy [1]
PyGObject GTK python-gobject [2]
PyQt Qt5/6 python-pyqt5/python-pyqt6 [3]
wxPython wxWidgets wxpython [4]

Weblinks