source: trunk/info/info/alkisn/alkisexport.php @ 391

Revision 391, 11.5 KB checked in by frank.jaeger, 7 years ago (diff)

ALKIS-Auskunft: Deutsches Datumsformat tt.mm.jjjj bei Geburtsdatum von Eigentümern und Entstehung des Flurstücks.

RevLine 
[362]1<?php
2/*      Modul alkisexport.php
[378]3        CSV-Export von ALKIS-Daten zu einem Flurstueck, Grundbuch, EigentÃŒmer oder Straße.
[362]4        Es wird eine GML-ID ÃŒbergeben.
5        Es wird ein gespeicherter View verwendet, der nach der gml_id gefiltert wird.
6        Der View verkettet Flurstueck - Buchungsstelle - Grundbuch - Eigentuemer
7        Die Lagebezeichnung des FlurstÃŒcks wird in ein Feld komprimiert.
[377]8        Parameter Beispiele:
[378]9                ?gkz=mandant&tabtyp=flurstueck/grundbuch/person/strasse&gmlid=DE...  Standard
10                ?gkz=270&tabtyp=gemarkung&gemarkung=2662         Sonderfall ganze Gemarkung
[377]11                ?gkz=270&gemarkung=2662
[378]12                ?gkz=mandant&tabtyp=strasse&haus=m&gmlid=DE...   Filter &haus=m/o = mit oder ohne Hausnummer
13                ?gkz=mandant&tabtyp=strasse&haus=o               bei Strasse auch ohne gmlid zulÀssig - nicht verwenden wenn aus NBA unscharf geladen
14        Beispiele fÃŒr Fehler:
[377]15                ?gkz=270&tabtyp=gemarkung&gmlid=2662
16                ?gkz=270&tabtyp=flurstueck&gemarkung=2662
17                ?gkz=270&tabtyp=flurstueck
18                ?gkz=270&gmlid=2662
[362]19
20        Version
[378]21        2016-02-23      Version fuer norGIS-ALKIS-Import
22        2016-10-18      Export einer ganzen Gemarkung zulassen (Sonderfall bei den Parametern)
23        2016-11-29      Gemeinsam genutzte Datenbanken ermöglichen
24        2017-02-23      Filter mit/ohne Hausnummer zum Typ "strasse".
25                                Dazu muss der View "exp_csv_str" um die spalte "fall" erweitert werden.
26                                Siehe Datei "x_classic2norgis.sql" in /OSGeo4W64/apps/alkis-import/postcreate.d/
27                                Sonderfall: Auch Export zu *allen* Straßen der Stadt ohne Filter "gmlid".
[387]28        2017-06-08 Validierung Eingabeparameter
[389]29        2017-10-11 Sauber filtern auf endet IS NULL
[387]30
31ToDo:
[391]32        - Geburtsdatum im deutschen Format DD.MM.YYYY ?
[387]33        - In Dateiname Straßenname statt gmlid verwenden?
34        - in alkislage.php fÃŒr den Typ "ohne Haunummer" den Export mit strasse und haus=o verlinken
[362]35*/
36
37function lage_zum_fs($gmlid) {
38        // Zu einem FlurstÃŒck die Lagebezeichnungen (mit Hausnummer) so aufbereiten,
39        // dass ggf. mehrere Lagebezeichnungen in eine Zelle der Tabelle passen.
40        // FS >westAuf> Lage >> Katalog
[387]41        $sql ="SELECT DISTINCT s.bezeichnung, l.hausnummer "
42        ."FROM ax_flurstueck f JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(f.weistauf) "
43        ."JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage "
[389]44        ."WHERE f.gml_id= $1 AND f.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ORDER BY s.bezeichnung, l.hausnummer;";
[362]45
46        $v=array($gmlid);
47        $res=pg_prepare("", $sql);
48        $res=pg_execute("", $v);
49        if (!$res) {return "** Fehler bei Lagebezeichnung **";}
50        $j=0;
51        $lagehsnr="";
52        $salt="";
53        while($row = pg_fetch_array($res)) {
54                if ($j > 0) {$lagehsnr.=", ";}
55                $sneu=$row["bezeichnung"];
56                if ($sneu == $salt) { // gleiche Str.
57                        $lagehsnr.=$row["hausnummer"]; // HsNr dran haengen
58                } else { // Name UND HsNr dranhaengen
59                        $lagehsnr.=$sneu." ".$row["hausnummer"];
60                }
61                $salt=$sneu; // Name f. naechste Runde
62                $j++;
63        }
64        pg_free_result($res);
65        return($lagehsnr);
66}
67
[375]68// HIER START //
69
[387]70$tabtyp='';  $haus=''; // mögliche Parameter initialisieren
71$cntget = extract($_GET); // Parameter in Variable umwandeln
72
73// strikte Validierung aller Parameter
74if (!isset($gmlid) or !preg_match('#^[0-9A-Za-z]{16}$#', $gmlid)) {die("Eingabefehler gmlid");}
75if (!isset($gkz) or !preg_match('#^[0-9]{3}$#', $gkz)) {die("Eingabefehler gkz");}
76if (isset($gemarkung)) {
77        if (!preg_match('#^[0-9]{4}$#', $gemarkung)) {die("Eingabefehler gemarkung");}
78} else {
79        $gemarkung='';
80}
81if (!preg_match('#^[m|o]{0,1}$#', $haus)) {die("Eingabefehler haus");}
82if (!preg_match('#^[a-z]{0,10}$#', $tabtyp)) {die("Eingabefehler tabtyp");}
83
[375]84require_once("alkis_conf_location.php"); // Konfiguration laden
85include("alkisfkt.php"); // Funktionen der ALKIS-Auskunft laden
86
87if ($tabtyp == '') { // Parameter (-kombinationen) pruefen
[378]88        if ($gemarkung != '') { // Dieser Parameters bestimmt auch eindeutig den $tabtyp
[375]89                $tabtyp = 'gemarkung';
[378]90        } else {  // Bei "gmlid" MUSS man zwingend die Tabelle dazu nennen
[387]91                $err="\nFehler: Art des Suchfilters nicht angeben.";
92                exit ($err);
[375]93        }
94} elseif ($tabtyp == 'gemarkung') {
95        if ($gemarkung == '') {
[387]96                $err="\nFehler: Gemarkungsnummer nicht angeben.";
97                exit ($err);
[375]98        }
99}
[378]100
101if ($gmlid != '') { // Angabe von gmlid ist der Normalfall, das passt fÃŒr fast jeden tabtyp
102        if ($tabtyp == 'strasse' and $haus != '') { // den Zusatzfilter m/o im Dateinamen dokumentieren
103                if ($haus == 'm') {
104                        $filename='alkis_'.$tabtyp.'_'.$gmlid.'_mit_hsnr.csv';
105                } else {  // = o
106                        $filename='alkis_'.$tabtyp.'_'.$gmlid.'_ohne_hsnr.csv.csv';
107                }
108        } else {
109                $filename='alkis_'.$tabtyp.'_'.$gmlid.'.csv';
110        }
111} else { // Oh Oh! Keine gmlid! - Alternativen?
112        if ($gemarkung != '') { // Sonderfall 1 - Gemarkungsnummer statt gmlid als Filter
[375]113                if ($tabtyp != 'gemarkung') {
[378]114                        $err = "Fehler: Falsche Kombination Parameter tabtyp='".$tabtyp."' mit Wert fuer Gemarkungsnummer.";
115                        echo "\n".$err; exit ($err);
[375]116                }
117                $filename='alkis_'.$tabtyp.'_'.$gemarkung.'.csv';
[378]118
119/*      // $gmlid zu strasse noch notwendig solange kein Filter auf "Gemeinde" verwendet wird.
120        } elseif ($haus == 'm' or $haus == 'o') { // Sonderfall 2 - alle mit/ohne Hausnummer, nur ÃŒber View "exp_csv_str" möglich
121                if ($tabtyp != 'strasse') {
[387]122                        $err="\nFehler: Falsche Kombination Parameter tabtyp='".$tabtyp."' mit Wert fuer Haus.";
123                        exit ($err);
[378]124                }
125                if ($haus == 'm') { // den Zusatzfilter m/o im Dateinamen dokumentieren
126                        $filename='alkis_'.$tabtyp.'_mit_hsnr.csv';
127                } else {
128                        $filename='alkis_'.$tabtyp.'_ohne_hsnr.csv';
129                }
130*/
131        } else {
[387]132                $err="\nFehler: Kein passender Wert fuer die Suche angegeben.";
133                exit ($err);
[375]134        }
135}
136
137// DOWNLOAD der CSV-Datei vorbereiten (statt HTML-Ausgabe)
[362]138header('Content-type: application/octet-stream');
[375]139header('Content-Disposition: attachment; filename="'.$filename.'"');
[362]140
141// CSV-Ausgabe: Kopfzeile mit Feldnamen
142echo "FS-Kennzeichen;GmkgNr;Gemarkung;Flur;Flurstueck;Flaeche;Adressen;GB-BezNr;GB-Bezirk;GB-Blatt;BVNR;Anteil_am_FS;Buchungsart;Namensnummer;AnteilDerPerson;RechtsGemeinschaft;Person;GebDatum;Anschrift;Anteil(berechnet)";
143
144// Datenbank-Verbindung
[377]145$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisexport.php'");
[378]146if (!$con) {
147        $err= "Fehler beim Verbinden der DB";
148        echo "\n".$err; exit($err);
149}
[387]150pg_set_client_encoding($con, 'LATIN1'); // FÃŒr Excel kein UTF8
[362]151
[387]152$viewname="exp_csv"; // Standard-View, in der DB gespeichert
[375]153$v=array($gmlid); // Standard-Filter-Feld
154
[362]155// Der Parameter "Tabellentyp" bestimmt den Namen des Filter-Feldes aus dem View "exp_csv".
156switch ($tabtyp) { // zulaessige Werte fuer &tabtyp=
[375]157        case 'flurstueck': // ax_flurstueck.gml_id
158                $filter = "fsgml";
159                break;
160        case 'grundbuch': // ax_buchungsblatt.gml_id
161                $filter = "gbgml";
162                break;
163        case 'person': // ax_person.gml_id
164                $filter = "psgml";
165                break;
166        case 'strasse': // ax_lagebezeichnungkatalogeintrag.gml_id = Straße-GML-ID
167                $filter = "stgml";
168                $viewname="exp_csv_str"; // alternativer View mit "_str", ist in der Datenbank gespeichert 
169                break;
170        case 'gemarkung': // SONDERfall als Parameter wird "Gemarkungsnummer" und nicht "gml_id" geliefert
171                $filter = "gemarkungsnummer";
172                $v=array($gemarkung); // anderes Filter-Feld, anderer Parameter
173                break;
174        default:
[387]175                $err="\nFalscher Parameter '".$tabtyp."'";
176                exit($err);
[375]177                break;
[362]178}
179
180// Daten aus gespeichertem View, zusaetzlich Filter: "feld"='wert' mitgeben
[375]181$sql="SELECT * FROM ".$viewname." WHERE ".$filter." = $1 ";
[362]182
[387]183if ($haus == 'm' or $haus == 'o') { // nur FS mit/ohne verschl. Lagebez.
[378]184        if ($gmlid == '') { // m/o-Filter als einziger Filter
185                $sql="SELECT * FROM ".$viewname." WHERE fall='".$haus."' "; // Ersetzen
186                $v=array(); // kein Filter-Feld
187                // ToDo: Filter auf Gemeinde notwendig, wenn nicht auf strasse gefiltert wird.
188                // - Sonst Ausgabe von Rand-FlurstÃŒcken (bei geometrischer Filterung des NBA-Verfahrens)
189                // - Sonst ggf. Ausgabe Kreisgebiet
[387]190        } else { // als zusÀtzlicher Filter AND
[378]191                $sql.="AND fall='".$haus."' "; // m/o-Filter AnhÀngen
192        }
193}
194
[362]195$res=pg_prepare("", $sql);
196$res=pg_execute("", $v);
[378]197if (!$res) {
[387]198        $err="\nFehler bei Datenbankabfrage";
199        exit($err);
[378]200}
[362]201$i=1; // Kopfzeile zÀhlt mit
202$fsalt='';
203
204// Datenfelder auslesen
205while($row = pg_fetch_array($res)) {
206        $i++; // Zeile der Tabelle
207        $rechnen=true; // Formel in letzte Spalte?
208
209        // Flurstueck
210        $fsgml=$row["fsgml"];
211        $fs_kennz=$row["fs_kennz"]; // Rechts Trim "_" ?
212        $gmkgnr=$row["gemarkungsnummer"];
213        $gemkname=$row["gemarkung"];
214        $flurnummer=$row["flurnummer"];
215        $flstnummer=$row["zaehler"];
216        $nenner=$row["nenner"];
217        // Bruchnummer kann in Excel als Datum interpretiert werden. In '' setzen.
218        if ($nenner > 0) {$flstnummer="'".$flstnummer."/".$nenner."'";} // BruchNr
219        $fs_flae=$row["fs_flae"]; // amtliche Fl. aus DB-Feld
220
221        // Grundbuch (Blatt)
222        $gb_bezirk=$row["gb_bezirk"]; // Nummer des Bezirks
223    $gb_beznam=$row["beznam"];    // Name des Bezirks
224        $gb_blatt=$row["gb_blatt"];
225
226        // Buchungsstelle (Grundstueck)
227        $bu_lfd=$row["bu_lfd"]; // BVNR
228        $bu_ant=$row["bu_ant"]; // '=zaehler/nenner' oder NULL
229        $bu_key=$row["buchungsart"]; // SchlÃŒssel
230        $bu_art=$row["bu_art"]; // entschlÃŒsselt (Umlaute in ANSI!)
231        if($bu_ant == '') { // Keine Bruch-Zahl
232                $bu_ant = '1'; // "voller Anteil" (Faktor 1)
233        } else {
234                $bu_ant=str_replace(".", ",", $bu_ant); // Dezimalkomma statt -punkt.           
235        }
236
237        // Namensnummer
238        $nam_lfd="'".kurz_namnr($row["nam_lfd"])."'"; // In Hochkomma, wird sonst wie Datum dargestellt.
239        $nam_ant=$row["nam_ant"];
240        $nam_adr=$row["nam_adr"]; // Art der Rechtsgemeischaft (SchlÃŒssel)
241
242        if ($nam_adr == '') {     // keine Rechtsgemeinschaft
243                $rechtsg='';
244                if ($nam_ant == '') { // und kein Bruch-Anteil
245                        $nam_ant=1; // dann ganzer Anteil
246                }
247        } else {
248                $rechnen=false; // bei Rechtsgemeinschaft die Anteile manuell interpretieren
249                if ($nam_adr == 9999) { // sonstiges
250                        $rechtsg=$row["nam_bes"]; // Beschrieb der Rechtsgemeinschaft
251                } else {
252                //      $rechtsg=rechtsgemeinschaft($nam_adr); // EntschlÃŒsseln
253                        $rechtsg=$row["nam_adrv"]; // Art der Rechtsgemeischaft (Value zum Key)
254                }
255        }
256
257        // Person
258        $vnam=$row["vorname"];
259        $nana=$row["nachnameoderfirma"];
260        $namteil=$row["namensbestandteil"];
261        //$name=anrede($row["anrede"]); 
262        $name=$row["anrv"]; // Anrede (Value zum Key)
263        if ($name != "") {$name.=" ";} // Trenner
264        if ($namteil != "") {$name.=$namteil." ";} // von und zu
265        $name.=$nana;
266        if ($vnam != "") {$name.=", ".$vnam;} // Vorname nach hinten
267        $gebdat=$row["geburtsdatum"];
268
269        // Adresse der Person (Eigentuemer))
270        $ort=$row["ort"];
271        if ($ort == "") {
272                $adresse="";
273        } else {
274                $adresse=$row["strasse"]." ".$row["hausnummer"].", ".$row["plz"]." ".$ort;
[387]275                $land=$row["land"]; // nur andere Laender anzeigen
[362]276                if (($land != "DEUTSCHLAND") and ($land != "")) {
277                        $adresse.=" (".$land.")";
278                }
279        }
280
281        // Adressen (Lage) zum FS
282        if($fsgml != $fsalt) { // nur bei geÀndertem Kennz.
283                $lage=lage_zum_fs($fsgml); // die Lage neu ermitteln
284                $fsalt=$fsgml;
285        }
286
287        // Den Ausgabe-Satz montieren aus FlurstÃŒcks-, Grundbuch- und Namens-Teil
288        //      A             B           C             D               E               F            G
289        $fsteil=$fs_kennz.";".$gmkgnr.";".$gemkname.";".$flurnummer.";".$flstnummer.";".$fs_flae.";".$lage.";";
290        //      H              I              J             K           L           M
291        $gbteil=$gb_bezirk.";".$gb_beznam.";".$gb_blatt.";".$bu_lfd.";".$bu_ant.";".$bu_art.";";
292        //       N            O            P            Q         R           S
293        $namteil=$nam_lfd.";".$nam_ant.";".$rechtsg.";".$name.";".$gebdat.";".$adresse;
294
295        // Anteile "GB am FS" und "Pers am GB" verrechnen
296        if ($rechnen) { // beide Anteile verwertbar
297                $formelteil=";=L".$i."*O".$i; // Spalte T
298        } else {
299                $formelteil=';';
300        }
301
302        // Ausgabe in die CSV-Datei -> Download -> Tabellenkalkulation
303        echo "\n".$fsteil.$gbteil.$namteil.$formelteil;
304}
305pg_free_result($res);
[378]306if ($i == 1) { // nur Kopf
[387]307        $err="\nKein Treffer fuer gml_id='".$gmlid."'";
308        exit ($err);
[378]309}
[362]310pg_close($con);
311exit(0);
312?>
Note: See TracBrowser for help on using the repository browser.