🙏 Helfen Sie jetzt mit, unser LibreOffice Forum zu erhalten! 🙏
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀

❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

Datenbank ResultSet als Dictionary verwenden

Alles zur Programmierung im LibreOffice.
Antworten
Pythonizer
Beiträge: 1
Registriert: Mi 14. Dez 2022, 13:33

Datenbank ResultSet als Dictionary verwenden

Beitrag von Pythonizer » Mi 14. Dez 2022, 13:55

Hi,
ich versuche mich aktuell an der Makro-Programmierung unter LibreOffice in Python. Ganz generell muss ich ja sagen, dass ich es ziemlich frustrierend finde. So ziemlich alles, was Python so schön angenehm zu programmieren macht funktioniert in der LO-Umgebung nicht, oder nicht wie erwartet. Man bekommt stark den Eindruck, dass all die Python-Funktionalität irgendwie nur aufgesetzt ist. Aber genug gemeckert, zu meinem eigentlichen Thema:

Ich habe ein ResultSet von einer Datenbankabfrage (aus Base) und würde dieses gerne Array-mäßig weiterverarbeiten, genau genommen als Dictionary. Dazu habe ich mir folgenden Generator gebaut:

Code: Alles auswählen

def convertToDict(rs):
    if not rs.supportsService("com.sun.star.sdbc.ResultSet"):
        raise AttributeError()
    columns = rs.getColumns()
    names = columns.getElementNames()
    types = tuple([col.Type for col in columns])
    while True:
        ret = {}
        for col in range(0, len(columns)):
            value = columns[col].Value
            if value is not None and types[col] == 91:
                tmp = rs.getDate(col+1)
                value = datetime.date(day=tmp.Day, month=tmp.Month, year=tmp.Year)
            ret[names[col]] = value
        yield ret
        if not rs.next():
            return
Grundsätzlich funktioniert das so eigentlich schon ganz gut und tut auch was ich will. Was mich jedoch stört ist diese Schleife mit der ich über die einzelnen Spalten innerhalb der Zeile iterieren muss. Gibt es da nichts besseres?
Für die Spaltennamen selbst kann ich mit getElementNames() ein Tupel bekommen, welches alle Namen enthält, aber ich konnte bisher nichts vergleichbares finden, um die komplette Zeile in einem Rutsch auszulesen.

Benutzeravatar
karolus
* LO-Experte *
Beiträge: 2536
Registriert: Fr 10. Dez 2010, 10:01

Re: Datenbank ResultSet als Dictionary verwenden

Beitrag von karolus » Mi 14. Dez 2022, 16:38

Hallo
Damit man das beurteilen kann, bräuchte es zumindest ein solches Resultset.
Also eher ein Base-dokument mit konkreten Datensätzen und der Abfrage.
LO7.4.7.5 debian 12(bookworm) auf Raspberry4b 8GB (64bit)
LO24.8.0.3 flatpak debian 12(bookworm) auf Raspberry4b 8GB (64bit)


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten