Seite 2 von 3
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Montag 23. April 2012, 12:33
von frabron
Ja, so kann man es machen, da stimme ich dir zu. Gerade der Teil mit der Konsistenz kann imo nicht überbewertet werden. Man könnte solche Hinweise natürlich noch etwas
stärker hervorheben. Keine Ahnung, ob Markdown da etwas anbietet. Inspiriert haben mich da ein paar Lehrbücher, da gibt es ja auch öfter mal so Kästchen und Zeigefinger-Grafiken.
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Montag 23. April 2012, 12:54
von Hyperion
Ja, solche Hervorhebungen wären schon nett. Genauso stört es mich, dass das Syntaxhighlighting für die Konsolensessions nicht gut funzt.
Also an alle Github-Erfahrenen: Gibt es da ein spezielles Highlighting? Und gibt es solche Hervorhebungen?
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Montag 23. April 2012, 13:15
von nomnom
Hyperion hat geschrieben:Genauso stört es mich, dass das Syntaxhighlighting für die Konsolensessions nicht gut funzt.
Dafür gibt es das „pycon“-Syntax-Highlighting, das aber nur für „normale“ Python-Sitzungen funktioniert.
Hyperion hat geschrieben:Und gibt es solche Hervorhebungen?
***Das ist die stärkste Hervorhebung.***

Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Montag 23. April 2012, 13:21
von Hyperion
nomnom hat geschrieben:Dafür gibt es das „pycon“-Syntax-Highlighting, das aber nur für „normale“ Python-Sitzungen funktioniert.
Also nicht für IPython? Ich werds mal testen, vielleicht ist das ja doch akzeptabel

Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Montag 23. April 2012, 14:12
von Leonidas
Ich würde IPython eh weglassen. Das verwirrt mehr als es wert ist.
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Freitag 27. April 2012, 09:12
von sma
Tolles Tutorial. Guter Schreibstil. Da muss ich im Vergleich mein Tutorial noch zurückhalten und überarbeiten
Ich schlage ebenfalls vor, auf IPython zu verzichten. Das verwirrt mehr, als es hilft, auch wenn es praktisch scheint, um auf Ausdrücke zu verweisen. Zudem finde ich's doof, dass Pygments das "ü" und "ö" als Fehler hervorhebt oder andere komische Dinge mit der Ausgabe macht.
Ich würde auch auf "sys.exit()" verzichten und einfach "break" benutzen. Das macht in den ersten Beispielen die Funktion "menu" wiederverwendbar.
Wenn du format() nicht zum Formatieren benutzt, würde statt
auch einfach
funktionieren. Und da ich eher ein Fan von "%" bin, würde ich wenn schon, dann
benutzen, damit auch Zahlen > 9 noch schön untereinander ausgerichtet werden.
Übrigens, man darf in einem Tutorial ruhig lügen, wenn es dem Verständnis dient. Die Aussage "alles ist ein Objekt" kann man IMHO so stehen lassen. Ich würde wahrscheinlich von Werten sprechen, nicht Objekten, um sie klar von Exemplaren abzugrenzen. Letztlich ist aber in Python AFAIK auch alles ein Exemplar einer Klasse, selbst Klassen. Etwas wie "ich kann jeden Wert in ein dict stecken" würde dann aber auch gehen. Der Exkurs "Funktionen sind auch Objekte" ist IMHO ein bisschen zu lang. Ehrlich gesagt würde ich Objekte komplett raus lassen und nur argumentieren, dass Funktionen Werte sind, und damit überall dort benutzt werden können, wo man andere Werte wie Zahlen oder Zeichenketten benutzen kann (sie sind "first class").
Bei
kannst du übrigens die Macht von Unicode spielen lassen
Als Tipp, wie es weitergehen könnte: Annotiere Funktionen mit `@menu(x)`, um sie auf diese Weise in ein Menü `x` einzufügen. Sie werden in der Reihenfolge eingefügt, wie sie im Quelltext stehen. Der letzte Punkt ist immer "Ende" bzw. "Zurück", wenn es sich um ein Untermenü handelt.
Stefan
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Freitag 27. April 2012, 11:14
von BlackJack
@sma: Ich mag ``%`` ja auch lieber, aber Zahlen auf x Stellen zu formatieren geht auch mit `format()`:
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 11:52
von sh4nks
Danke für dieses Tutorial
Ich hätte noch eine kleine Frage beim submenu
Was macht das
underline?
Konnte bei Google nichts finden, da ich nicht weiß was die genaue Bezeichnung ist
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 11:57
von cofi
sh4nks hat geschrieben:Was macht das
underline?
Konnte bei Google nichts finden, da ich nicht weiß was die genaue Bezeichnung ist
Der under_score_ hat in Python keine besondere Bedeutung, sondern ist ein ein ganz normaler Bezeichner.
Fuer Programmierer hat er aber meistens zu bedeuten "Ich bekomme Werte, die ich nicht nutze, und will das kenntlich machen".
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 12:08
von /me
sh4nks hat geschrieben:Was macht das
underline
Das ist ein ganz normaler gültiger Name für einen Bezeichner. Der Code hätte statt
auch
aussehen können, vor allem da der erste Parameter im folgenden Code nicht mehr verwendet wird.
Und das ist genau der Knackpunkt an der Sache. Eine nicht unerhebliche Anzahl von Python-Entwicklern verwenden den Unterstrich als Bezeichner an Stellen wo ein Bezeichner gebraucht wird, der anschließend keine Rolle mehr spielt. Der Unterstrich ist absolut nichtssagend und genau das ist es, was die Bedeutung dieses Parameters dort im Code ausmacht.
Ab und zu wird der Unterstrich von manchen Entwicklern auch als Verkürzung für oft verwendete Funktionen benutzt.
Code: Alles auswählen
>>> from __future__ import print_function
>>> _ = print
>>> _('Hallo')
Hallo
Ich mag diesen Einsatz nicht so. Er konterkariert PEP-20 (Zen of Python) und PEP-8 bei den Punkten "Readability counts." unter besonderer Berücksichtigung von "code is read much more often than it is written".
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 14:50
von sh4nks
Ah ok danke.
Dies würde aber so auch funktionieren:
Ist es eine schlechte Idee das so zu verwenden?
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 14:57
von Dav1d
Das würde auch funktionieren, nur macht es mMn. unleserlicher.
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 16:18
von sma
/me hat geschrieben:Ich mag diesen Einsatz [gemeint ist der Unterstrich] ]nicht so. Er konterkariert PEP-20 (Zen of Python) und PEP-8 bei den Punkten "Readability counts." unter besonderer Berücksichtigung von "code is read much more often than it is written"
Ich finde den "_" im Gegenteil "intention revealing" und auch wenn Python das im Gegensatz zu anderen Sprachen nicht als Teil der Semantik kennt, ist es IMHO guter Stil. Ein anderes Beispiel wäre "i" für eine Schleifenvariable oder das man eine Pluralform wählt, wenn man eine Collection von Dingen bezeichnen will.
Die Python-IDE PyCharm weiß bei ihrer heuristischen Typanalyse beispielsweise, dass sie das "_" nicht an unbenutzt Variable markieren soll. Würde man `foo, bar = foobars` schreiben und dann `foo` nie wieder benutzen, würde PyCharm das als wahrscheinlichen anmerken.
Stefan
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 16:26
von /me
sma hat geschrieben:Ich finde den "_" im Gegenteil "intention revealing" und auch wenn Python das im Gegensatz zu anderen Sprachen nicht als Teil der Semantik kennt, ist es IMHO guter Stil. Ein anderes Beispiel wäre "i" für eine Schleifenvariable oder das man eine Pluralform wählt, wenn man eine Collection von Dingen bezeichnen will.
Hier scheine ich den Kontext nicht deutlich genug gemacht zu haben. Ich mag den Unterstrich "als Verkürzung für oft verwendete Funktionen" nicht, sonst durchaus.
sma hat geschrieben:Die Python-IDE PyCharm ...
Gerade habe ich noch 66,70€ für das Upgrade Subscription Renewal ausgegeben. Und das mir als FSFE-Fellow ...
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Dienstag 1. Mai 2012, 16:37
von sma
/me hat geschrieben:Hier scheine ich den Kontext nicht deutlich genug gemacht zu haben. Ich mag den Unterstrich "als Verkürzung für oft verwendete Funktionen" nicht, sonst durchaus.
Ach so. Ja, das teile ich.
sma hat geschrieben:Die Python-IDE PyCharm ...
/me hat geschrieben:Gerade habe ich noch 66,70€ für das Upgrade Subscription Renewal ausgegeben. Und das mir als FSFE-Fellow ...
Wird nicht immer gepredigt: Free != Kostenlos

Gute Software darf ruhig etwas kosten, finde ich.
Außerdem: Die Grund-IDE von Jetbrains für Java, Scala und Android ist ja außerdem auch als Opensource verfügbar...
Stefan
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Mittwoch 2. Mai 2012, 01:17
von Leonidas
sma hat geschrieben:sma hat geschrieben:Die Python-IDE PyCharm ...
/me hat geschrieben:Gerade habe ich noch 66,70€ für das Upgrade Subscription Renewal ausgegeben. Und das mir als FSFE-Fellow ...
Wird nicht immer gepredigt: Free != Kostenlos

Gute Software darf ruhig etwas kosten, finde ich.
PyCharm ist aber weder "free" noch "kostenlos", von daher fällt dieser Vergleich flach.
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Mittwoch 2. Mai 2012, 08:10
von jens
Noch Anmerkungen von mir: Bei Code Beispielen die absichtlich "schlecht" sind, würde ich davor darauf hinweisen.
Das folgende, würde ich anders machen:
Code: Alles auswählen
def get_user_input(menu):
while True:
try:
choice = int(input("Ihre Wahl?: ")) - 1
if 0 <= choice < len(menu):
return choice
else:
raise IndexError
except (ValueError, IndexError):
print("Bitte nur Zahlen aus dem Bereich 1 - {} eingeben".format(
len(menu)))
def handle_menu(menu):
while True:
print_menu(menu)
choice = get_user_input(menu)
menu[choice][1]()
eh so:
Code: Alles auswählen
def get_user_input(menu):
while True:
try:
choice = int(raw_input("Ihre Wahl?: "))
choice -= 1
return menu[choice][1]
except (ValueError, IndexError):
print("Bitte nur Zahlen aus dem Bereich 1 - {} eingeben".format(
len(menu)))
def handle_menu(menu):
while True:
print_menu(menu)
func = get_user_input(menu)
func()
...und ganz wichtig: überall statt
input() lieber
raw_input() nehmen! Und kurz erwähnen, das
input() eigentlich
eval(raw_input(prompt)) ist und das ist keine gute Idee.
Im Tutorial kannst du dann noch kurz auf try...except eingehen und es fehlt IMHO am Ende ein Beispiel das funktioniert. Also noch die pseudo Funktionen dabei packen. Dann kann man direkt copy&paste und probieren.
und zum Schluss, das ganze in's Wiki packen

Der fertige Code kann ja bei github bleiben und verlinkt werden...
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Mittwoch 2. Mai 2012, 08:29
von BlackJack
@jens: `raw_input()` ist in Python 3 in `input()` umbenannt worden.
Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Mittwoch 2. Mai 2012, 11:27
von snafu
sma hat geschrieben:Wenn du format() nicht zum Formatieren benutzt, würde statt
auch einfach
Oder um genau zu sein:

Re: Tutorial: Einfache Textmenüs mit Python
Verfasst: Donnerstag 3. Mai 2012, 19:36
von Hyperion
Danke für die weiteren Anmerkungen. Ich war einige Tage offline und muss das erst einmal in Ruhe durchlesen und mir überlegen, was ich wie umsetze.