Skip to content

Python3 - QT_QPA_PLATFORM

Python3
  • Nach meinem Umzug auf Ubuntu 21.04 hatte ich doch mit meinem VSCodium ein kleines Problem, was aber nervte 🙂 Hier ein Bild.

    Problem.jpeg

    Links ist mein Restic UI, wenn ich es aus dem Ordner aufrufe. Rechts der Aufruf aus VSCodium heraus. Wie man sieht, passt das "Design" nicht. Ich habe jetzt bestimmt zwei Tage ziemlich viel gelesen und ausprobiert und nichts funktionierte 😞 Ja, so was kommt vor. Aber auch auf einen kleinen Hilferuf bei Twitter meldete sich leider niemand. Also musste ich das selber lösen. Also heute noch mal ran an die Sache.

    Kurze Erklärung,. Auf meinem Linux Mint Cinnamon (X-System) hatte ich keinerlei Probleme. So mit war ich mir relativ sicher, das es irgendwas mit Wayland zu tuen hatte, aber was !? Die heutige Internetrecherche brachte mich dann auf diese Seite.

    Dort stolperte ich über das hier

    $QT_QPA_PLATFORM

    This controls how Qt apps run. It can be set to xcb for X11 or wayland-egl for Wayland.

    Über dieses QT_QPA_PLATFORM war ich schon öfter gestolpert, aber das stand immer was anderes und nichts funktionierte. Hier stand mal was anderes und zwar xcb und wayland-egl.

    wayland-egl getestet mit

    export QT_QPA_PLATFORM=wayland-egl
    

    Also, in VSCodium ein Terminal aufgemacht und dort eingegeben. Danach das Programm gestartet. Nix, immer noch nackig. Also testen wir das andere.

    export QT_QPA_PLATFORM=xcb
    

    Und zack, das Fenster sieht so aus wie es auf Ubuntu 21.04 der Standard ist.

    373375aa-f1a6-4f35-91bb-b81ec1a4fa11-grafik.png

    Ok, so weit war ich erst mal zufrieden. Das ist aber nur eine temporäre Lösung, weil nach einem Neustart usw. ist das wieder weg. Aber, auch dafür gibt es eine einfache Lösung. Wir editieren unser Profil.

    frank@frank-MS-XXXX:~/Downloads$ nano ~/.profile
    

    In diese Datei fügen wir ans Ende diese Zeile hinzu.

    # This controls how Qt apps run. It can be set to xcb for X11 or wayland-egl for Wayland.
    export QT_QPA_PLATFORM=xcb
    

    Abspeichern - Fertig! Nun startet das PyQt5 Programm mit dem richtigen "Design".

    Frank wieder glücklich 🤓

  • Nachdem ich ja mittlerweile schon lange weder auf Cinnamon bin, hatte ich nach einem Update von VSCodium wieder ein anderes Design. Ok, schauen wir rein.

    (venv) frank@frank-MS-7C37:~/restic-ui-public$ env | grep "QT"
    QT_ACCESSIBILITY=1
    QT_QPA_PLATFORMTHEME=qt5ct
    

    Wenn ich das auf

    QT_QPA_PLATFORMTHEME=gnome3
    

    ändere, sieht es wie auf meinem Linux Mint Cinnamon Desktop aus.

  • Python3 - pyqtSignal

    Python3
    1
    0 Stimmen
    1 Beiträge
    82 Aufrufe
    Niemand hat geantwortet
  • PyQt5 - QThread

    Python3
    3
    0 Stimmen
    3 Beiträge
    181 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
    2
    0 Stimmen
    2 Beiträge
    121 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']
  • Python3 - Popen und seine Geheimnisse ;)

    Python3
    1
    0 Stimmen
    1 Beiträge
    186 Aufrufe
    Niemand hat geantwortet
  • Python3 - HTML Text ausgeben

    Python3
    1
    0 Stimmen
    1 Beiträge
    134 Aufrufe
    Niemand hat geantwortet
  • Python3 - class BackupList

    Python3
    2
    0 Stimmen
    2 Beiträge
    229 Aufrufe
    FrankMF

    Mir hat heute jemand auf Twitter zu meinem Problem geantwortet.

    Das habe ich natürlich direkt, bei einer Tasse Kaffee, ausprobiert. Geht einwandfrei und ein Problem ist damit Vergangenheit. Bei meiner Konstruktion musste ich immer eine Länge für die Liste p vorgeben.

    p = list(range(10))

    Das wird jetzt nicht mehr benötigt. Schön 🙂

    Jetzt muss ich mir das noch in Ruhe anschauen, nachlesen und verstehen.

    Danke für den netten Hinweis!

  • Python3 - subprocess.Popen

    Python3
    1
    0 Stimmen
    1 Beiträge
    269 Aufrufe
    Niemand hat geantwortet
  • Python3 - JSON

    Python3
    3
    0 Stimmen
    3 Beiträge
    197 Aufrufe
    FrankMF

    ede1a88a-5183-4f85-a602-27650362d532-grafik.png

    Die Backups sollen Namen haben, also habe ich das erweitert. Jetzt sollen diese als Liste rechts angezeigt werden. Das mache ich wie folgt.

    for key in backups: print(backups[key]['name'], key) liste = backups[key]['name'] + " ID: " + key self.listWidget.addItem(liste)

    Mittels des Keys kann ich auf den Namen zugreifen und die Liste damit füllen. Aktuell habe ich noch den Key hinten angefügt, weil ich noch keine Idee habe, wie ich die Backups anders verarbeiten soll. Aber, Stück für Stück. Der Backup-Name wird nach Auswahl in der Statusbar angezeigt. So weit klappt das so wie ich mir das vorstelle. Für heute ist Feierabend 😇