Seite 1 von 1

Anfängerfrage: Bedeutung von \ in der Dokumentation

Verfasst: Donnerstag 24. Oktober 2024, 13:17
von EmKay
Vielen Dank für die Aufnahme.

Seit Wochenanfang beschäftige ich mich Python. Gerade wird in dem Buch das Thema Zahlensysteme besprochen. Bei der Instanziierung von int können ein Anfangswert und ein Zahlensystem übergegeben werden.

Code: Alles auswählen

class int(number=0, /)
class int(string, /, base=10)
Mich verwirt die Angabe von /. Zur Bedeutung habe ich bisher nichts gefunden. Gerne möchte ich die Dokumentation verstehen. Warum wurde hier / mit angegeben. Wenn int('6', 6) ausreichend ist?

Re: Anfängerfrage: Bedeutung von \ in der Dokumentation

Verfasst: Freitag 25. Oktober 2024, 08:19
von sparrow
Vorsicht vor den Details. Der Backslash ( \ ), den du in deinem Topic-Titel verwendest ist etwas anderes als der Slash ( / ) der tatsächlich im Code auftaucht.

Ich denke auch nicht, dass der Code, den du hier präsentierst tatsächlich richtig ist.
Das steht exakt so in deinem Lehrbuch? Mit dem class Keyword vorweg?!

Es gibt zwei "special characters" in Parameterlisten von Funktionen/Methoden (und das kann auch die __init__-Methode einer Klasse sein):

/: Links davon stehen "positional arguments" (diese können nicht über den Namen übergeben werden) und rechts "positional arguments" oder "keyword arguments".
*: Links stehen "positional arguments" oder "keyword arguments" und rechts nur "keyword arguments" (diese können ausschließlich über ihren Namen übergeben werden).

Code: Alles auswählen

>>> def slash(a, /, b):
...     print(a, b)
...
>>> slash(1, 2)
1 2
>>> slash(1, b=2)
1 2
>>> slash(a=1, b=2)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: slash() got some positional-only arguments passed as keyword arguments: 'a'
>>> def asterisk(a, *, b):
...     print(a, b)
...
>>> asterisk(1, b=2)
1 2
>>> asterisk(a=1, b=2)
1 2
>>> asterisk(1, 2)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: asterisk() takes 1 positional argument but 2 were given
>>>

Re: Anfängerfrage: Bedeutung von \ in der Dokumentation

Verfasst: Freitag 25. Oktober 2024, 08:35
von DeaD_EyE
Den "/" gab es zuerst nur in der Dokumentation.
Module, die in C geschrieben worden sind, haben mit dem "/" markiert, dass keine positionsabhängige Argumente mehr folgen.
Dann wurde es irgendwann im Python-Standard aufgenommen.

Re: Anfängerfrage: Bedeutung von \ in der Dokumentation

Verfasst: Freitag 25. Oktober 2024, 12:45
von __blackjack__
@EmKay: Wobei ``/`` bei in Python geschriebenen Funktionen/Methoden eigentlich keinen Sinn macht. Für C wurde das gebraucht, weil man bei entsprechenden Funktionen/Methoden die Argumente vor dem ``/`` nicht als Schlüsselwortargumente angeben konnte, wenn der C-Code das technisch nicht unterstützt hat. Da hätte man extra Code für schreiben müssen. Bei in Python geschriebenen Funktionen/Methoden geht das technisch aber immer.

Der Datentyp `int` ist in CPython in C implementiert.

Die Bedeutung findet man übrigens in der Python-Dokumentation. Die HTML-Version hat auf fast jeder Seite oben rechts einen Link zum Index. Dort dann „Symbols“ und unter dem Eintrag für `/ (slash)` findet man function definition und da dann unter anderem die Erklärung was ``*`` und ``/`` allein stehend in einer Parameterliste bedeuten.

Wenn es um Syntax oder Namen aus der Standardbibliothek geht, findet man über den Index meistens recht gezielt die relevante(n) Stelle(n) in der Dokumentation.

Re: Anfängerfrage: Bedeutung von \ in der Dokumentation

Verfasst: Montag 28. Oktober 2024, 09:17
von EmKay
sparrow hat geschrieben: Freitag 25. Oktober 2024, 08:19 Vorsicht vor den Details. Der Backslash ( \ ), den du in deinem Topic-Titel verwendest ist etwas anderes als der Slash ( / ) der tatsächlich im Code auftaucht.
Da hat sich ein Tippfehler eingeschlichen. Gemeint ist der Slash
sparrow hat geschrieben: Freitag 25. Oktober 2024, 08:19 Ich denke auch nicht, dass der Code, den du hier präsentierst tatsächlich richtig ist.
Das steht exakt so in deinem Lehrbuch? Mit dem class Keyword vorweg?!
Den Code habe ich so von der Python-Dokumentationsseite übernommen. int

Vielen Dank für Eure ausführlichen Antworten. Meine Frage ist damit beantwortert.