Datenbank mit Variable aus Python füllen

2 Antworten

Die Frage ist, ob Dein Python überhaupt eine Datenbankanbindung vorgesehen hat. Normalerweise ist das eine Netzwerkverbindung und Deine Python-Entwicklungsumgebung muss diese Anbindung, auch wenn das lokal ist, irgendwie im Programm realisieren. Zum Testen müsste die CONNECT-Anweisung ohne Fehlermeldung akzeptiert werden. Konkret bedeutet das, dass das was Du an die Datenbank sendest auch dort ankommt und die Datenbank Dir eine entsprechende Meldung zurücksendet. Wenn das funktioniert, kann man über die weiteren SQL-Anweisungen diskutieren.


ju5t1n 
Beitragsersteller
 15.01.2015, 18:16

Ja also die Verbindung klappt. Feste Values kann ich übertragen. Ich habe mittlerweile den Fehler gefunden. Die Datenbankspalte für pressure und temperature muss von Decimal auf Float geändert werden. dann gehts.

generell würde ich mir die systemspezifische fehlermeldung ausgeben lassen, wie in http://www.mikusa.com/python-mysql-docs/exceptions.html beschrieben.

lt. beschreibung musst du jedenfalls immer %s statt (?) benutzen (auch für die numerischen felder)

ich weis nicht, ob du da uns in deinem code etwas vorenthalten hast: die variablen temperature, pressure wie im 2. parameter vom execute angegeben sind in deinem code nicht zu sehen, wohl aber temperature1, pressure1 (oder meinst du die etwa?)


ju5t1n 
Beitragsersteller
 15.01.2015, 18:13

Ja Sry, das war wohl in der Eile. Die 1 nach temperature und pressure ist ein fehler. Im script was dem Raspberry gegeben wurde, ist dies natürlich anders geschrieben. Ich wollte mich bei der Frage einfach auf das Wichtigste konzentrieren. Ich habe mittlerweile selber den Fehler gefunden nach vielen Stunden herumprobieren. Der Fehler liegt nicht am Script, sondern an den Einstellungen der Datenbank. Ersteinmal müssen die "(?)" dürch "%s" ersetzt werden. Dann muss man den Fehler beheben wie die Datenbank angelegt wird. Hier nochmal wie ich es gemacht habe:

CREATE TABLE wetterdata (date DATE, time TIME, temperature NUMERIC, pressure NUMERIC);

Das Problem liegt daran dass NUMERIC die Spalte als Decimal definiert. Scheinbar kann weder (?) noch %s die werte korrekt übertragen. Ich habe nun in der Datenbank über die GUI PHPMyAdmin die Decimal in Float geändert und auf einmal ging es mit %s. Bisschen strange das ganze aber so klappt es gut.

Trotzdem danke dass ihr euch mit meinem Problem auseinandergesetzt habt!