Tipps und Tricks aus meinem Telegrammkanal @pythonetc, November 2019
Es ist eine neue Auswahl von Tipps und Tricks zu Python und Programmierung aus meinem Telegramm-Kanal @pythonetc.
←
Frühere Publikationen .
PATH
ist eine Umgebungsvariable, die Pfade speichert, in denen nach ausführbaren Dateien gesucht wird. Wenn Sie Ihre Shell
ls
,
ls
auszuführen, sucht sie über alle in PATH angegebenen Pfade nach der ausführbaren Datei
ls
.
$ echo $PATH /usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/v.pushtaev/.local/bin:/home/v.pushtaev/bin $ which ls /usr/bin/ls
Im obigen Beispiel sind die Pfade durch
:
Zeichen getrennt
:
in PATH. Es ist kein Escape-Vorgang möglich: Ein Pfad, der Folgendes enthält
:
kann nicht innerhalb von
PATH
.
Dies gilt jedoch nicht für alle Betriebssysteme. In Python können Sie mit
os.pathsep
das richtige Trennzeichen für das lokale System
os.pathsep
:
Python 3.5.0 [...] on win32 Type "help", "copyright", "credits" or "license" for more information. >>> import os >>> os.pathsep ';'
os.pathsep
nicht mit
os.path.sep
, dem Trennzeichen für Dateipfade:
>>> os.path.sep '/'
Um reguläre Ausdrücke besser lesbar zu machen, können Sie das Flag
re.VERBOSE
verwenden. Sie können zusätzliche Leerzeichen verwenden, wo immer Sie möchten, und Kommentare mit dem Symbol
#
hinzufügen:
import re URL_RE = re.compile(r''' ^ (https?):// (www[.])? ( (?: [^.]+[.] )+ ( [^/]+ ) # TLD ) (/.*) $ ''', re.VERBOSE) m = URL_RE.match('https://www.pythonetc.com/about/') schema, www, domain, tld, path = m.groups() has_www: bool = bool(www) print(f'schema={schema}, has_www={has_www}') print(f'domain={domain}, tld={tld}') print(f'path={path}')
re.X
ist ein Alias für
re.VERBOSE
.
complex
ist der in Python integrierte Typ für komplexe Zahlen:
>>> complex(1, 2).real 1.0 >>> abs(complex(3, 4)) 5.0 >>> complex(1, 2) == complex(1, -2).conjugate() True >>> str(complex(2, -3)) '(2-3j)'
Es ist jedoch nicht erforderlich, es direkt zu verwenden, da Python Literale für komplexe Zahlen enthält:
>>> (3 + 4j).imag 4.0 >>> not (3 + 4j) False >>> (-3 - 4j) + (2 - 2j) (-1-6j)
a : b : c
Notation
a : b : c
kann verwendet werden, um
slice(a, b, c)
nur in Klammern zu definieren:
>>> [1, 2, 3, 4, 5][0:4:2] [1, 3] >>> [1, 2, 3, 4, 5][slice(0, 4, 2)] [1, 3]
Wenn Sie das Slice-Objekt als Argument an eine Funktion übergeben möchten, müssen Sie es explizit definieren:
def multislice(slc, *iterables): return [i[slc] for i in iterables] print(multislice( slice(2, 6, 2), [1, 2, 3, 4, 5, 6, 7], [2, 4, 2, 4, 2, 4, 2], ))
So konvertieren Sie eine solche Funktion in ein Objekt, das
[a : b : c]
:
from functools import partial class SliceArgDecorator: def __init__(self, f): self._f = f def __getitem__(self, slc): return partial(self._f, slc) slice_arg = SliceArgDecorator @slice_arg def multislice(slc, *iterables): return [i[slc] for i in iterables] print(multislice[2:6:2]( [1, 2, 3, 4, 5, 6, 7], [2, 4, 2, 4, 2, 4, 2], ))
__getattribute__
ist ein leistungsstarkes Tool, mit dem Sie Delegierungsmuster bei Bedarf problemlos verwenden können. So fügen Sie die Fähigkeit hinzu, mit einem nicht vergleichbaren Objekt vergleichbar zu sein:
class CustomEq: def __init__(self, orig, *, key): self._orig = orig self._key = key def __lt__(self, other): return self._key(self) < self._key(other) def __getattribute__(self, name): if name in {'_key', '_orig', '__lt__'}: return super().__getattribute__(name) return getattr(self._orig, name) class User: def __init__(self, user_id): self._user_id = user_id def get_user_id(self): return self._user_id def comparable(obj, *, key): return CustomEq(obj, key=key) user1 = comparable(User(1), key=lambda u: u.get_user_id()) user2 = comparable(User(2), key=lambda u: u.get_user_id()) print(user2 > user1)