[FOSSGIS-Talk] QGIS - Python-Makros, ALKIS-Plugin Datenbankzugriff

Bernhard Ströbl bernhard.stroebl at jena.de
Fr Feb 16 10:12:33 CET 2018


Hallo Peter,
dann solltest Du es mal in openProject() versuchen
einfach die if-Bedingung (if host == "") rauslassen

Ich habe das in einer Erweiterung drin, die was anderes macht 
(allerdings schon was mit Flurstücken), aber da war für mich halt eine 
Möglichkeit, den Wert zu setzen, so dass alle Nutzer das eingetragen 
haben. Manche ändern das aber dann auf ihren persönlichen DB-Zugriff 
(mit Eigentümerauskunft), weshalb ich immer prüfen muß, ob schon was 
eingetragen ist. Bei uns gibt es aber auch nur eine ALKIS-DB

Berichte doch bitte, ob Du mit projectOpen erfolgreich warst.

Grüße
Bernhard

Am 16.02.2018 um 10:05 schrieb sk:
> Hallo Bernhard,
> 
> genau das war mein Gedanke, einfach QGIS-Projektdatei starten und die 
> entsprechende DB wird als Wert gesetzt.
> Das ich den Weg direkt über die Registry gegangen bin ist halt dem 
> Umstand geschuldet, dass ich vom Programmieren eigentlich null Ahnung
> habe. Mit Python versuche ich es seit einiger Zeit in sehr kleinen 
> Schritten und im Web habe ich halt diese Variante gefunden.
> 
> Hier ist es halt so das es einmal die Nutzer gibt die einmal in der 
> Woche oder noch weniger QGIS nutzen oder halt wie ich, der am Tag 
> dreimal das Projekt
> wechselt und jedes mal wieder schaut wie die entsprechende DB denn heißt.
> Wenn ich es direkt mit dem QGIS-Projekt verbinden könnte bräuchte keine 
> Rücksicht auf vorhandene Werte genommen werden.
> 
> Also hast Du eine eigene Erweiterung die das für dich erledigt, wenn ich 
> das richtig verstanden habe.
> Wie kann ich Deine Variante umsetzen? Sollte man eine Erweiterung 
> erstellen, nachvollziehen kann ich es nicht.
> 
> Das Plugin PostNAS-Suche wird auch verwendet, das wäre dann die nächste 
> Baustelle gewesen.
> 
> Gruß Peter
> 
> Am 16.02.2018 um 09:26 schrieb Bernhard Ströbl:
>> Hallo Peter,
>> was möchtest Du erreichen? Ich vermute mal, dass bei allen die das 
>> Projekt öffnen, die Datenbank eingetragen ist. Ob es sinnvoll ist, das 
>> direkt in der Registry zu machen, weiß ich nicht, Qt bietet dafür 
>> QSettings an, hier ist mein Code (stammt im Prinzip aus dem 
>> alkis-Plugin von norbit wird in einem anderen Plugin ausgeführt). Im 
>> Moment nimmt das Rücksicht darauf, dass ein Nutzer evtl. etwas anderes 
>> eingestellt hat
>>
>> #setze default-Werte für norbit alkis-Plugin
>> host = s.value( "host", "" )
>>
>> if host == "": # noch nicht gesetzt
>>     s.setValue( "host", "DBSERVER" )
>>     s.setValue( "port", "5432" )
>>     s.setValue( "dbname", "DBNAME" )
>>     s.setValue( "uid", "USERID" )
>>     s.setValue( "pwd", "PASSWORT" )
>>     s.setValue("modellarten",[u'DLKM', u'DKKM1000'])
>>
>> inwieweit das in OpenProject funktioniert, weiß ich nicht.
>> Falls Du auch das Plugin PostNAS-Suche benutzt, wäre der Code 
>> folgendermassen:
>>
>> # PostNAS-Suche:
>> s = QtCore.QSettings( "PostNAS", "PostNAS-Suche" )
>> host = s.value( "host", "" )
>>
>> if host == "": # noch nicht gesetzt
>>     s.setValue( "host", "DBSERVER" )
>>     s.setValue( "port", "5432" )
>>     s.setValue( "dbname", "DBNAME" )
>>     s.setValue( "uid", "USERID" )
>>     s.setValue( "pwd", "PASSWORT" )
>>
>> Bernhard



__________ Information from ESET Mail Security, version of virus signature database 16913 (20180216) __________

The message was checked by ESET Mail Security.
http://www.eset.com




Mehr Informationen über die Mailingliste FOSSGIS-Talk-Liste