suchen
HeimBackend-EntwicklungPython-TutorialPython-CLIs wartbarer machen: Eine Reise mit dynamischem Befehlsladen

Making Python CLIs More Maintainable: A Journey with Dynamic Command Loading

Dieser Blogbeitrag beschreibt eine aktuelle Verbesserung der Befehlszeilenschnittstelle (CLI) unseres HyperGraph-Projekts: ein dynamisches Befehlsladesystem. Ursprünglich war das Hinzufügen neuer CLI-Befehle ein mehrstufiger manueller Prozess, der gegen die DRY-Prinzipien und das Open/Closed-Prinzip verstieß.

Die Herausforderung: Manuelle Befehlsregistrierung

Das Hinzufügen eines neuen Befehls ist erforderlich:

  1. Erstellung der Implementierungsdatei des Befehls.
  2. Aktualisierung der Importe innerhalb von __init__.py.
  3. Hinzufügen des Befehls zu einer statischen Liste im Befehlsladeprogramm.

Dies war mühsam, fehleranfällig und erforderte die Änderung des vorhandenen Codes für jede neue Funktion – alles andere als ideal.

Lösungen erkunden: Automatisierung vs. dynamisches Laden

Zwei Lösungen wurden in Betracht gezogen:

  1. Ein Automatisierungsskript zur Verarbeitung von Dateiänderungen.
  2. Ein dynamisches Ladesystem, das die Modulerkennungsfunktionen von Python nutzt.

Während ein Automatisierungsskript zunächst einfacher erschien, würde es nur die Symptome beheben, nicht den zugrunde liegenden Designfehler.

Die Lösung: Dynamic Command Discovery

Die gewählte Lösung war ein dynamisches Ladesystem, das Befehle automatisch registriert. Der Kerncode lautet:

async def load_commands(self) -> None:
    implementations_package = "hypergraph.cli.commands.implementations"

    for _, name, _ in pkgutil.iter_modules([str(self.commands_path)]):
        if name.startswith("_"):  # Skip private modules
            continue

        module = importlib.import_module(f"{implementations_package}.{name}")

        for item_name, item in inspect.getmembers(module):
            if (inspect.isclass(item) and 
                issubclass(item, BaseCommand) and 
                item != BaseCommand):

                command = item(self.system)
                self.registry.register_command(command)

Dieser Ansatz bietet mehrere Vorteile:

  • Entfällt die manuelle Befehlsregistrierung.
  • Behält die Abwärtskompatibilität mit vorhandenem Code bei.
  • Vereinfacht das Hinzufügen neuer Befehle zum Platzieren einer neuen Datei im Verzeichnis implementations.
  • Nutzt Standard-Python-Bibliotheken und folgt der Philosophie „Batterien im Lieferumfang enthalten“.

Wichtige Erkenntnisse

  1. Vermeiden Sie schnelle Lösungen:Während die Automatisierung kurzfristige Erleichterung bot, bietet dynamisches Laden eine nachhaltigere, langfristigere Lösung.
  2. Kompatibilität bewahren: Durch die Beibehaltung der ursprünglichen CommandRegistry Methoden wird sichergestellt, dass vorhandener Code weiterhin funktioniert.
  3. Robuste Fehlerbehandlung: Umfassende Fehlerbehandlung und -protokollierung sind für das Debuggen in einem dynamischen System von entscheidender Bedeutung.

Ein kleiner Rückschlag

Ein kleines Problem trat mit einem fehlenden Typimport (Any aus typing) auf, was die Bedeutung einer gründlichen Typangabe in Python verdeutlicht.

Zukünftige Schritte

Während das dynamische System implementiert ist, bleibt ein Automatisierungsskript als Entwicklungstool zum Generieren von Befehlsdateivorlagen eine Möglichkeit. Zukünftige Pläne umfassen:

  • Überwachung der Produktionsleistung.
  • Entwickler-Feedback sammeln.
  • Implementierung weiterer Verbesserungen basierend auf der realen Nutzung.

Fazit

Dieses Refactoring zeigt die Vorteile einer Neubewertung von Ansätzen für elegantere Lösungen. Auch wenn der anfängliche Aufwand größer ist als bei einer schnellen Lösung, ist das Ergebnis besser wartbarer, erweiterbarer und pythonischer Code. Die Priorisierung der langfristigen Wartbarkeit vereinfacht die zukünftige Entwicklung.

Tags: #Python #Refactoring #CleanCode #CLI #Programmierung


Detaillierte technische Informationen finden Sie in unserem Codeberg-Repository.

Das obige ist der detaillierte Inhalt vonPython-CLIs wartbarer machen: Eine Reise mit dynamischem Befehlsladen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Was sind die Alternativen zur Verkettung von zwei Listen in Python?Was sind die Alternativen zur Verkettung von zwei Listen in Python?May 09, 2025 am 12:16 AM

Es gibt viele Methoden, um zwei Listen in Python zu verbinden: 1. Verwenden Sie Operatoren, die in großen Listen einfach, aber ineffizient sind; 2. Verwenden Sie die Erweiterungsmethode, die effizient ist, die ursprüngliche Liste jedoch ändert. 3.. Verwenden Sie den operator =, der sowohl effizient als auch lesbar ist; 4. Verwenden Sie die Funktion iterertools.chain, die Speichereffizient ist, aber zusätzlichen Import erfordert. 5. Verwenden Sie List Parsing, die elegant ist, aber zu komplex sein kann. Die Auswahlmethode sollte auf dem Codekontext und den Anforderungen basieren.

Python: Effiziente Möglichkeiten, zwei Listen zusammenzuführenPython: Effiziente Möglichkeiten, zwei Listen zusammenzuführenMay 09, 2025 am 12:15 AM

Es gibt viele Möglichkeiten, Python -Listen zusammenzuführen: 1. Verwenden von Operatoren, die einfach, aber nicht für große Listen effizient sind; 2. Verwenden Sie die Erweiterungsmethode, die effizient ist, die ursprüngliche Liste jedoch ändert. 3. Verwenden Sie iTertools.chain, das für große Datensätze geeignet ist. 4. Verwenden Sie * Operator, fusionieren Sie kleine bis mittelgroße Listen in einer Codezeile. 5. Verwenden Sie Numpy.concatenate, das für große Datensätze und Szenarien mit hohen Leistungsanforderungen geeignet ist. 6. Verwenden Sie die Append -Methode, die für kleine Listen geeignet ist, aber ineffizient ist. Bei der Auswahl einer Methode müssen Sie die Listengröße und die Anwendungsszenarien berücksichtigen.

Kompiliert gegen interpretierte Sprachen: Vor- und NachteileKompiliert gegen interpretierte Sprachen: Vor- und NachteileMay 09, 2025 am 12:06 AM

CompiledLanguageOfferSpeedandSecurity, während interpretedLanguagesProvideaseofuseAnDportabilität.1) kompiledlanguageslikec areFasterandSecurebuthavelongerDevelopmentCyclesandplatformDependency.2) InterpretedLanguages ​​-pythonareaToReAndoreAndorePortab

Python: Für und während Schleifen der vollständigste LeitfadenPython: Für und während Schleifen der vollständigste LeitfadenMay 09, 2025 am 12:05 AM

In Python wird eine für die Schleife verwendet, um iterable Objekte zu durchqueren, und eine WHHE -Schleife wird verwendet, um Operationen wiederholt durchzuführen, wenn die Bedingung erfüllt ist. 1) Beispiel für Schleifen: Überqueren Sie die Liste und drucken Sie die Elemente. 2) Während des Schleifens Beispiel: Erraten Sie das Zahlenspiel, bis Sie es richtig erraten. Mastering -Zyklusprinzipien und Optimierungstechniken können die Code -Effizienz und -zuverlässigkeit verbessern.

Python verkettet listet in eine Zeichenfolge aufPython verkettet listet in eine Zeichenfolge aufMay 09, 2025 am 12:02 AM

Um eine Liste in eine Zeichenfolge zu verkettet, ist die Verwendung der join () -Methode in Python die beste Wahl. 1) Verwenden Sie die monjoy () -Methode, um die Listelemente in eine Zeichenfolge wie "" .Join (my_list) zu verkettet. 2) Für eine Liste, die Zahlen enthält, konvertieren Sie die Karte (STR, Zahlen) in eine Zeichenfolge, bevor Sie verkettet werden. 3) Sie können Generatorausdrücke für komplexe Formatierung verwenden, wie z. 4) Verwenden Sie bei der Verarbeitung von Mischdatentypen MAP (STR, MIXED_LIST), um sicherzustellen, dass alle Elemente in Zeichenfolgen konvertiert werden können. 5) Verwenden Sie für große Listen '' .Join (large_li

Pythons Hybridansatz: Zusammenstellung und Interpretation kombiniertPythons Hybridansatz: Zusammenstellung und Interpretation kombiniertMay 08, 2025 am 12:16 AM

Pythonusesahybridapproach, kombinierte CompilationTobyteCodeAnDinterpretation.1) codiscompiledtoplatform-unintenpendentBytecode.2) BytecodeIsinterpretedBythepythonvirtualMachine, EnhancingEfficiency und Portablabilität.

Erfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsErfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsMay 08, 2025 am 12:11 AM

Die Keedifferzences -zwischen Pythons "für" und "während" Loopsare: 1) "für" LoopsareideAlForiteratingOvercesorknownowniterations, während 2) "LoopsarebetterForContiningUtilAconditionismethoutnredefineditInations.un

Python verkettet Listen mit DuplikatenPython verkettet Listen mit DuplikatenMay 08, 2025 am 12:09 AM

In Python können Sie Listen anschließen und doppelte Elemente mit einer Vielzahl von Methoden verwalten: 1) Verwenden von Operatoren oder erweitert (), um alle doppelten Elemente beizubehalten; 2) Konvertieren in Sets und kehren Sie dann zu Listen zurück, um alle doppelten Elemente zu entfernen. Die ursprüngliche Bestellung geht jedoch verloren. 3) Verwenden Sie Schleifen oder listen Sie Verständnisse auf, um Sätze zu kombinieren, um doppelte Elemente zu entfernen und die ursprüngliche Reihenfolge zu verwalten.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)