Skip to content

Python3 - Globale Variablen

Python3
1 1 164
  • Wenn man mit Python3 anfängt, merkt man sehr schnell, das es lokale und globale Variablen gibt.

    Lokale Variable

    def test():
        a = 5
        print("IN: ", a)
    
    test()
    
    print("OUT: ", a)
    

    Ergebnis

    $ python3 test2.py 
    IN:  5
    Traceback (most recent call last):
      File "test2.py", line 8, in <module>
        print("OUT: ", a)
    NameError: name 'a' is not defined
    

    Grund dafür ist, das die Variable a nur lokal innerhalb der Funktion gilt. Außerhalb kann man nicht darauf zugreifen. Das kann man so ändern.

    Globale Variable

    def test():
        global a
        a = 5
        print("IN: ", a)
    
    test()
    
    print("OUT: ", a)
    

    Ergebnis

    $ python3 test2.py 
    IN:  5
    OUT:  5
    

    Somit kann man die Variable auch außerhalb der Funktion benutzen. Man merkt aber sehr schnell beim Coden, das das nicht besonders geschickt ist. Man muss das überall explizit angeben usw. Dann, wenn man im Internet nach einer Lösung sucht, stolpert man immer wieder über die Aussage "das sei kein guter Programmierstil". Ok, wir wollen es ja von Anfang an richtig machen. Aber wie??

    config.py

    Ich bin dann über diese Webseite gestolpert. Dort legt man eine config.py an, diese wird dann importiert und einem stehen diese Variablen dann global zur Verfügung.

    Habe das ausprobiert und es funktionierte.

    config.py

    a = 5
    

    test.py

    import config
    
    def test():
        print("IN: ", config.a)
    
    test()
    
    print("OUT: ", config.a)
    

    Ergebnis

    $ python3 test2.py 
    IN:  5
    OUT:  5
    

    Das geht schon deutlich besser und man kann überall auf die Variable zugreifen. Aber irgendwie ist das ja immer noch unprofessionell !?

    Klasse

    Da ich ja auch gerne ein wenig das OOP erlernen möchte, muss das ja auch irgendwie mit den Klassen in Python3 gehen.Hier ein Praxisbeispiel 🙂 Ich möchte eine Datei öffnen und brauche zur weiteren Verarbeitung die Daten.

    class OpenFile():
            """
            Klasse zum Speichern von Filename & Path eines geöffneten Files!
            """
    
            def __init__(self,filename, path):
                self.filename = filename
                self.path = path
    
    # Hier erstellen wir das Objekt für die Klasse OpenFile
    file1 = OpenFile("test.txt", "/home/frank")
    
    print(file1.filename)
    print(file1.path)
    
    def test():
            print("IN: ", file1.filename)
            print("IN: ", file1.path)
    
    test()
    

    Kurze Erklärung.

    • Wir erstellen eine Klasse OpenFile()
    • Wir weisen dieser Klasse ein Objekt file1 zu
    • Wir printen die Daten
    • Wir printen die Daten mittels einer Funktion

    Ergebnis

    $ python3 test2.py 
    test.txt
    /home/frank
    IN:  test.txt
    IN:  /home/frank
    

    Wir sehen, das man jetzt schön von überall auf die Daten zugreifen kann. Damit sollte mein Problem gelöst sein. Und das sieht schon deutlich besser aus und ist wesentlich eleganter zu verarbeiten.

    An die Profis, die hier mitlesen sollten, über Verbesserungen jeder Art freue ich mich sehr. Vor allen Dingen, falls hier grober Unsinn steht, bitte verbessern! Es gibt im Netz soviel Unsinn, da muss hier nicht noch mehr stehen 😉 Nutzt die Kommentarfunktion - Danke!

  • Python3 - pyqtSignal

    Python3 python3 restic-ui
    1
    0 Stimmen
    1 Beiträge
    120 Aufrufe
    Niemand hat geantwortet
  • Python3 - Pipenv für die virtuelle Entwicklungsumgebung

    Python3 python3 pipenv
    2
    1
    0 Stimmen
    2 Beiträge
    447 Aufrufe
    FrankMF
    Ich ko... immer, wenn ich mein VSCodium neu installieren muss. Das größte Problem dabei ist immer, das ich fast immer vergesse den Python Interpreter zu setzen. "CTRL+SHIFT+P" and choose the correct python interpreter. [image: 1656256156412-46f85075-4dbc-414c-94c2-abc5bb6009b6-grafik.png] Danach startet das Python Programm auch wieder aus der richtigen Entwicklungsumgebung
  • Python3 - PyQt6 installieren

    Python3 pyqt6 python3
    1
    0 Stimmen
    1 Beiträge
    431 Aufrufe
    Niemand hat geantwortet
  • PyQt5 - QThread

    Python3 pyqt5 python3
    3
    0 Stimmen
    3 Beiträge
    286 Aufrufe
    FrankMF
    Und hier mal ein komplettes Beispiel. class Worker Wir legen den Worker an, das ist der Prozess der die Arbeit macht und etwas länger braucht. class Worker(QObject): """ Worker Class for Rest function stats""" stats_finished = pyqtSignal(str) stats_error = pyqtSignal(str) def __init__(self): super().__init__() def run(self): # Restic function try: # long running task except Exception: # Process don't successful, send signal self.stats_error.emit(result.stderr) else: # Process successful, send signal self.stats_finished.emit(result.stdout) finally: pass in class MainWindow class MainWindow(QMainWindow): def __init__(self): super().__init__() "First Thread with documentation" # Worker for restic_stats # Create a QThread object self.thread = QThread() # Create a worker object self.worker1 = Worker() # Move worker to the thread self.worker1.moveToThread(self.thread) # Connect signals and slots self.thread.started.connect(self.worker1.run) self.worker1.stats_finished[str].connect(self.restic_stats_finished) self.worker1.stats_error[str].connect(self.restic_stats_error) "First thread end" ############################################### # Process for restic_stats is finished ############################################### @pyqtSlot(str) def restic_stats_finished(self, i): # Signal from worker thread without an error Spinner.stop(self) self.thread.quit() ############################################### # Process for restic_stats when get an error ############################################### @pyqtSlot(str) def restic_stats_error(self, i): # Signal from worker thread with an error! Spinner.stop(self) Funktion restic_stats def restic_stats(self): # we start the worker thread self.thread.start() # we start waitingspinnerwidget Spinner.start(self) Ich wollte gerade schreiben, das folgendes sehr wichtig ist self.thread.quit() da fällt mir ein Fehler auf. Kurz ausprobiert und bingo, wenn der Prozess einen Error triggert, muss natürlich auch der Prozess beendet werden. Wenn man das nicht macht, macht das Programm nicht das was es soll. Der Grund ist, das der Prozess einfach immer weiter läuft. Er MUSS beendet werden. Ich gehe dann mal in meinem Programm alles ändern Ok, jetzt geht die Funktion auch zweimal hintereinander und gibt auch ordentlich den Fehler aus. Fazit Ich habe wieder sehr viel gelernt und hoffe das ich es auch richtig verstanden habe Hoffe das es dem ein oder anderen Anfänger hilft. Und falls hier ein Profi mitliest und hier Blödsinn steht bitte ich um einen Kommentar, damit ich das ändern kann. Es steht schon genug Blödsinn im Netz
  • Python3 - PyQt5 QIcon

    Python3 pyqt5 python3
    2
    2
    0 Stimmen
    2 Beiträge
    185 Aufrufe
    FrankMF
    Die Suchpfade findet man hiermit print(QIcon.themeSearchPaths()) Ausgabe ['/home/frank/.icons', '/usr/share/cinnamon/icons', '/var/lib/flatpak/exports/share/icons', '/usr/share/icons', ':/icons']
  • Restic UI - Documentation

    Restic UI restic-ui python3 pyqt5
    1
    1
    0 Stimmen
    1 Beiträge
    349 Aufrufe
    Niemand hat geantwortet
  • Python3 - Popen und seine Geheimnisse ;)

    Python3 restic restic-ui python3
    1
    0 Stimmen
    1 Beiträge
    218 Aufrufe
    Niemand hat geantwortet
  • Wichtige Links

    Angeheftet Python3 python3
    1
    0 Stimmen
    1 Beiträge
    220 Aufrufe
    Niemand hat geantwortet