WIP script for importing BEV adressregister
This commit is contained in:
56
scripts/addressdb/addressdb_delete_multiple_streets.php
Normal file
56
scripts/addressdb/addressdb_delete_multiple_streets.php
Normal file
@@ -0,0 +1,56 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
|
||||
//require 'vendor/autoload.php';
|
||||
require("../config/config.php");
|
||||
|
||||
define('FRONKDB_SQLDEBUG',false);
|
||||
error_reporting(E_ALL & ~(E_NOTICE | E_STRICT | E_DEPRECATED));
|
||||
|
||||
require_once(LIBDIR."/mvcfronk/mfRouter/mfRouter.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseModel.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
|
||||
|
||||
$me = new User(1);
|
||||
|
||||
$db = FronkDB::singleton(ADDRESSDB_DBHOST, ADDRESSDB_DBUSER, ADDRESSDB_DBPASS, ADDRESSDB_DBNAME);
|
||||
|
||||
$db->select("Strasse", "*");
|
||||
if(!$db->num_rows($res)) {
|
||||
die("Keine Strassen gefunden\n");
|
||||
}
|
||||
|
||||
//echo "!!num rows: ".$db->num_rows($res)."\n";
|
||||
|
||||
$streets = [];
|
||||
$toDelete = [];
|
||||
$i = 0;
|
||||
$c = 0;
|
||||
|
||||
while($data = $db->fetch_object($res)) {
|
||||
$idx = $data->name."--".$data->gemeinde_id;
|
||||
//echo "$idx\n";
|
||||
|
||||
if(array_key_exists($idx, $streets)) {
|
||||
$toDelete[] = $data->id;
|
||||
//echo "!!num rows: ".$db->num_rows($res)."\n";
|
||||
} else {
|
||||
$streets[$idx] = $data->id;
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
|
||||
|
||||
|
||||
//var_dump(count($toDelete));exit;
|
||||
|
||||
foreach($toDelete as $id) {
|
||||
$s = new ADBStrasse($id);
|
||||
if($s->id === $id) {
|
||||
$s->delete();
|
||||
$c++;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo "Deleted $c duplicate streets ($i).\n";
|
||||
96
scripts/addressdb/addressdb_home_update.php
Executable file
96
scripts/addressdb/addressdb_home_update.php
Executable file
@@ -0,0 +1,96 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
|
||||
//require 'vendor/autoload.php';
|
||||
require("../config/config.php");
|
||||
|
||||
define('FRONKDB_SQLDEBUG',false);
|
||||
error_reporting(E_ALL & ~(E_NOTICE | E_STRICT | E_DEPRECATED));
|
||||
|
||||
require_once(LIBDIR."/mvcfronk/mfRouter/mfRouter.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseModel.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
|
||||
|
||||
$me = new User(1);
|
||||
|
||||
$filename = BASEDIR."/scripts/import/premstaetten_homes.csv";
|
||||
|
||||
$db = FronkDB::singleton(ADDRESSDB_DBHOST, ADDRESSDB_DBUSER, ADDRESSDB_DBPASS, ADDRESSDB_DBNAME);
|
||||
$log = mfLoghandler::singleton();
|
||||
|
||||
$input = fopen($filename, "r");
|
||||
|
||||
$h_extrefs = [];
|
||||
|
||||
$updated = 0;
|
||||
|
||||
$current_home_count = 0;
|
||||
$current_building_extref = "";
|
||||
$i = 0;
|
||||
while($csv = fgetcsv($input, 0, ";")) {
|
||||
$i++;
|
||||
if($i == 1) continue;
|
||||
|
||||
if(!trim($csv[0])) {
|
||||
continue;
|
||||
} else {
|
||||
$building_extref = $csv[1];
|
||||
$wohneinheit_extref = $csv[0];
|
||||
|
||||
if($current_building_extref != $building_extref) {
|
||||
// check how many homes we imported for this building
|
||||
$hausnummer = ADBHausnummerModel::getFirst(['extref' => $current_building_extref]);
|
||||
if($hausnummer) {
|
||||
$units = ADBWohneinheitModel::search(['hausnummer_id' => $hausnummer->id]);
|
||||
if(count($units) < $current_home_count) {
|
||||
echo "Weniger Homes vorhanden, als importiert (hausnummer extref: ".$hausnummer->extref.") building_extref $building_extref\n";
|
||||
}
|
||||
}
|
||||
|
||||
$current_home_count = 0;
|
||||
}
|
||||
$current_home_count++;
|
||||
$current_building_extref = $building_extref;
|
||||
|
||||
$hausnummer = ADBHausnummerModel::getFirst(['extref' => $building_extref]);
|
||||
if(!$hausnummer) {
|
||||
echo "Hausnummer nicht gefunden: $building_extref\n";
|
||||
continue;
|
||||
}
|
||||
|
||||
$existing_units = ADBWohneinheitModel::search(['hausnummer_id' => $hausnummer->id]);
|
||||
|
||||
$current_unit = $existing_units[$current_home_count -1];
|
||||
if(!$current_unit) {
|
||||
// transmission stations may not have been created
|
||||
//echo "unit for $wohneinheit_extref not found\n";
|
||||
continue;
|
||||
}
|
||||
$current_unit->extref = $wohneinheit_extref;
|
||||
$current_unit->save();
|
||||
$updated++;
|
||||
|
||||
|
||||
|
||||
/*if($current_home_count > count($existing_units)) {
|
||||
echo "creating unit $wohneinheit_extref (hausnummer $building_extref)\n";
|
||||
$unit_data = [
|
||||
'extref' => $wohneinheit_extref,
|
||||
'hausnummer_id' => $hausnummer->id,
|
||||
'num' => $current_home_count,
|
||||
'tuer' => $current_home_count,
|
||||
'nutzung' => "Wohnung"
|
||||
];
|
||||
|
||||
$unit = ADBWohneinheitModel::create($unit_data);
|
||||
//var_dump($unit);exit;
|
||||
//if(!$unit->save()) {
|
||||
// die("Error saving new unit\n");
|
||||
//}
|
||||
}*/
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo "Updated $updated units\n";
|
||||
19
scripts/addressdb/addressdb_import.php
Executable file
19
scripts/addressdb/addressdb_import.php
Executable file
@@ -0,0 +1,19 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
|
||||
//require 'vendor/autoload.php';
|
||||
require("../config/config.php");
|
||||
|
||||
define('FRONKDB_SQLDEBUG',false);
|
||||
error_reporting(E_ALL & ~(E_NOTICE | E_STRICT | E_DEPRECATED));
|
||||
|
||||
require_once(LIBDIR."/mvcfronk/mfRouter/mfRouter.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseModel.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
|
||||
|
||||
$me = new User(1);
|
||||
|
||||
$filename = BASEDIR."/scripts/import/agwr_premstaetten_sample_v2.csv";
|
||||
|
||||
$adb = new AddressDB();
|
||||
$adb->import($filename);
|
||||
240
scripts/addressdb/addressdb_import_bev_adressregister.php
Executable file
240
scripts/addressdb/addressdb_import_bev_adressregister.php
Executable file
@@ -0,0 +1,240 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
|
||||
//require 'vendor/autoload.php';
|
||||
require("../../config/config.php");
|
||||
|
||||
define('FRONKDB_SQLDEBUG',false);
|
||||
error_reporting(E_ALL & ~(E_NOTICE | E_STRICT | E_DEPRECATED));
|
||||
|
||||
require_once(LIBDIR."/mvcfronk/mfRouter/mfRouter.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseModel.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
|
||||
|
||||
$me = new User(1);
|
||||
|
||||
$folder = BASEDIR."/scripts/addressdb/import/bev";
|
||||
$db = FronkDB::singleton(ADDRESSDB_DBHOST, ADDRESSDB_DBUSER, ADDRESSDB_DBPASS, ADDRESSDB_DBNAME);
|
||||
$log = mfLoghandler::singleton();
|
||||
|
||||
/*
|
||||
* Import Gemeinden
|
||||
*/
|
||||
|
||||
$filename = "$folder/GEMEINDE.csv";
|
||||
$input = fopen($filename, "r");
|
||||
|
||||
$i = 0;
|
||||
while($csv = fgetcsv($input, 0, ";")) {
|
||||
$i++;
|
||||
if($i == 1) continue;
|
||||
|
||||
if(!trim($csv[0])) {
|
||||
continue;
|
||||
} else {
|
||||
$gkz = trim($csv[0]);
|
||||
$gemeinde_name = trim($csv[1]);
|
||||
|
||||
$gemeinde = getGemeinde($gkz);
|
||||
if(!$gemeinde) {
|
||||
// create Gemeinde
|
||||
$gemeinde = ADBGemeindeModel::create([
|
||||
'kennziffer' => $gkz,
|
||||
'code' => $gkz,
|
||||
'name' => $gemeinde_name
|
||||
]);
|
||||
$gemeinde_id = $gemeinde->save();
|
||||
if(!$gemeinde_id) {
|
||||
die("Fehler beim Speichern der Gemeinde ($gkz, $gemeinde_name)\n");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo ($i-1)." Gemeinden importiert\n";
|
||||
|
||||
/*
|
||||
* Import Ortschaften
|
||||
*/
|
||||
|
||||
$filename = "$folder/ORTSCHAFT.csv";
|
||||
$input = fopen($filename, "r");
|
||||
|
||||
$i = 0;
|
||||
while($csv = fgetcsv($input, 0, ";")) {
|
||||
$i++;
|
||||
if($i == 1) continue;
|
||||
|
||||
if(!trim($csv[0])) {
|
||||
continue;
|
||||
} else {
|
||||
$gkz = trim($csv[0]);
|
||||
$okz = trim($csv[1]);
|
||||
$ortschaft_name = trim($csv[2]);
|
||||
|
||||
$gemeinde = getGemeinde($gkz);
|
||||
if(!$gemeinde) {
|
||||
die("Kann Ortschaft nicht importieren: Gemeinde nicht gefunden ($gkz)\n");
|
||||
}
|
||||
|
||||
$ortschaft = ADBOrtschaftModel::getFirst(["kennziffer" => $okz]);
|
||||
if(!$ortschaft) {
|
||||
$ortschaft = ADBOrtschaftModel::create([
|
||||
'gemeinde_id' => $gemeinde->id,
|
||||
'kennziffer' => $okz,
|
||||
'name' => $ortschaft_name
|
||||
]);
|
||||
$ortschaft_id = $ortschaft->save();
|
||||
if(!$ortschaft_id) {
|
||||
die("Fehler beim Speichern der Ortschaft ($okz, $ortschaft_name)\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo ($i-1)." Ortschaften importiert\n";
|
||||
|
||||
/*
|
||||
* Import Strassen
|
||||
*/
|
||||
|
||||
$filename = "$folder/STRASSE.csv";
|
||||
$input = fopen($filename, "r");
|
||||
|
||||
$i = 0;
|
||||
while($csv = fgetcsv($input, 0, ";")) {
|
||||
$i++;
|
||||
if($i == 1) continue;
|
||||
|
||||
if($i % 1000 == 0) {
|
||||
echo ".";
|
||||
}
|
||||
|
||||
if(!trim($csv[0])) {
|
||||
continue;
|
||||
} else {
|
||||
$skz = trim($csv[0]);
|
||||
$strasse_name = trim($csv[1]);
|
||||
$gkz = trim($csv[4]);
|
||||
|
||||
if(!$skz) continue;
|
||||
|
||||
$gemeinde = getGemeinde($gkz);
|
||||
if(!$gemeinde) {
|
||||
die("Kann Strasse nicht importieren: Gemeinde nicht gefunden ($gkz)\n");
|
||||
}
|
||||
|
||||
$strasse = ADBStrasseModel::getFirst(["kennziffer" => $skz]);
|
||||
if(!$strasse) {
|
||||
if($gemeinde->id == 1) {
|
||||
// Adresse in Premstaetten
|
||||
// try to find strasse by fuzzy name
|
||||
$strasse_search = [$db->escape($strasse_name)];
|
||||
|
||||
if(strpos($strasse_name, ' ') !== false) $strasse_search[] = $db->escape(str_replace(' ', '-', $strasse_name));
|
||||
if(strpos($strasse_name, '-') !== false) $strasse_search[] = $db->escape(str_replace('-', ' ', $strasse_name));
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = $db->escape(str_replace('.', '. ', $strasse_name));
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = $db->escape(str_replace('.', '.-', $strasse_name));
|
||||
if(strpos($strasse_name, '. ') !== false) $strasse_search[] = $db->escape(str_replace('. ', '.', $strasse_name));
|
||||
if(strpos($strasse_name, '. ') !== false) $strasse_search[] = $db->escape(str_replace('. ', '.-', $strasse_name));
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = $db->escape(str_replace('.-', '.', $strasse_name));
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = $db->escape(str_replace('.-', '. ', $strasse_name));
|
||||
|
||||
foreach($strasse_search as $search) {
|
||||
if(strpos($search, 'ß') !== false) $strasse_search[] = $db->escape(str_replace('ß', 'ss', $search));
|
||||
if(strpos($search, 'ä') !== false) $strasse_search[] = $db->escape(str_replace('ä', 'ae', $search));
|
||||
if(strpos($search, 'ö') !== false) $strasse_search[] = $db->escape(str_replace('ö', 'oe', $search));
|
||||
if(strpos($search, 'ü') !== false) $strasse_search[] = $db->escape(str_replace('ü', 'ue', $search));
|
||||
|
||||
if(strpos($search, 'ss') !== false) $strasse_search[] = $db->escape(str_replace('ss', 'ß', $search));
|
||||
if(strpos($search, 'ae') !== false) $strasse_search[] = $db->escape(str_replace('ae', 'ä', $search));
|
||||
if(strpos($search, 'oe') !== false) $strasse_search[] = $db->escape(str_replace('oe', 'ö', $search));
|
||||
if(strpos($search, 'ue') !== false) $strasse_search[] = $db->escape(str_replace('ue', 'ü', $search));
|
||||
}
|
||||
|
||||
|
||||
$strasse_ids = [];
|
||||
|
||||
$sql = "SELECT * FROM Strasse WHERE name IN ('". implode("', '", $strasse_search)."') AND gemeinde_id=".$gemeinde->id;
|
||||
//echo $sql."\n";
|
||||
$res = $db->query($sql);
|
||||
if($db->num_rows($res) > 1) {
|
||||
echo "Found multiple streets for '$strasse_name' in Gemeinde ".$gemeinde->name." (".$gemeinde->id.")\n";
|
||||
while($data = $db->fetch_object($res)) {
|
||||
$strasse_ids[] = $data->id;
|
||||
}
|
||||
} elseif($db->num_rows($res)) {
|
||||
$data = $db->fetch_object($res);
|
||||
$strasse_ids[] = $data->id;
|
||||
//echo "Found matching street for '$strasse_name': ".$data->name."\n";
|
||||
}
|
||||
|
||||
if(count($strasse_ids)) {
|
||||
// update skz for eisting streets
|
||||
foreach($strasse_ids as $strasse_id) {
|
||||
$strasse = new ADBStrasse($strasse_id);
|
||||
$strasse->kennziffer = $skz;
|
||||
|
||||
if($strasse_name != $strasse->name) {
|
||||
echo "Updating strasse name from '".$strasse->name."' to '$strasse_name' (".$strasse->id.")\n";
|
||||
$strasse->name = $strasse_name;
|
||||
}
|
||||
|
||||
if(!$strasse->save()) {
|
||||
echo "Fehler beim Speichern der Strase ($skz, $strasse_name, ".$gemeinde->name.")\n";
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// create strasse
|
||||
|
||||
$strasse = ADBStrasseModel::create([
|
||||
'gemeinde_id' => $gemeinde->id,
|
||||
'kennziffer' => $skz,
|
||||
'name' => $strasse_name
|
||||
]);
|
||||
$strasse_id = $strasse->save();
|
||||
if(!$strasse_id) {
|
||||
die("Fehler beim Speichern der Ortschaft ($okz, $ortschaft_name)\n");
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// nicht in premstätten
|
||||
// create strasse
|
||||
|
||||
$strasse = ADBStrasseModel::create([
|
||||
'gemeinde_id' => $gemeinde->id,
|
||||
'kennziffer' => $skz,
|
||||
'name' => $strasse_name
|
||||
]);
|
||||
$strasse_id = $strasse->save();
|
||||
if(!$strasse_id) {
|
||||
die("Fehler beim Speichern der Ortschaft ($okz, $ortschaft_name)\n");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
echo "\n".($i-1)." Straßen importiert\n";
|
||||
|
||||
|
||||
$gemeinden_cache = [];
|
||||
function getGemeinde($kz) {
|
||||
global $gemeinden_cache;
|
||||
|
||||
if(array_key_exists($kz, $gemeinden_cache)) {
|
||||
return $gemeinden_cache[$kz];
|
||||
}
|
||||
|
||||
$gemeinde = ADBGemeindeModel::getFirst(['kennziffer' => $kz]);
|
||||
if(!$gemeinde) {
|
||||
return false;
|
||||
}
|
||||
$gemeinden_cache[$kz] = $gemeinde;
|
||||
return $gemeinde;
|
||||
}
|
||||
370
scripts/addressdb/addressdb_update.php
Executable file
370
scripts/addressdb/addressdb_update.php
Executable file
@@ -0,0 +1,370 @@
|
||||
#!/usr/bin/php
|
||||
<?php
|
||||
|
||||
//require 'vendor/autoload.php';
|
||||
require("../config/config.php");
|
||||
|
||||
define('FRONKDB_SQLDEBUG',false);
|
||||
error_reporting(E_ALL & ~(E_NOTICE | E_STRICT | E_DEPRECATED));
|
||||
|
||||
require_once(LIBDIR."/mvcfronk/mfRouter/mfRouter.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseModel.php");
|
||||
require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
|
||||
|
||||
$me = new User(1);
|
||||
|
||||
$filename = BASEDIR."/scripts/import/premstaetten_buildings.csv";
|
||||
|
||||
$db = FronkDB::singleton(ADDRESSDB_DBHOST, ADDRESSDB_DBUSER, ADDRESSDB_DBPASS, ADDRESSDB_DBNAME);
|
||||
$log = mfLoghandler::singleton();
|
||||
|
||||
$input = fopen($filename, "r");
|
||||
|
||||
$h_extrefs = [];
|
||||
|
||||
$i = 0;
|
||||
while($csv = fgetcsv($input, 0, ";")) {
|
||||
$i++;
|
||||
if($i == 1) continue;
|
||||
|
||||
|
||||
$hausnummer = false;
|
||||
|
||||
if(!trim($csv[0])) {
|
||||
continue;
|
||||
} else {
|
||||
//echo implode(", ", $csv)."\n";
|
||||
$gem_kz = trim($csv[17]);
|
||||
$gem_name = trim($csv[18]);
|
||||
//$ort_kz = trim($csv[2]);
|
||||
$plz_name = trim($csv[5]);
|
||||
$ort_name = trim($csv[6]);
|
||||
$strasse_hausnummer = trim($csv[4]);
|
||||
$hausnummer_extref = trim($csv[1]);
|
||||
if(in_array($hausnummer_extref, $h_extrefs)) {
|
||||
die("Hausnummer extref doppelt!\n");
|
||||
}
|
||||
$h_extrefs[] = $hausnummer_extref;
|
||||
|
||||
$lat = str_replace(",",".",trim($csv[7]));
|
||||
$long = str_replace(",",".",trim($csv[8]));
|
||||
|
||||
$netzgebiet_extref = trim($csv[14]);
|
||||
if(!$netzgebiet_extref) continue;
|
||||
$netzgebiet = new ADBNetzgebiet();
|
||||
$netzgebiet->loadByExtref($netzgebiet_extref);
|
||||
if(!$netzgebiet->id) {
|
||||
die("Netzgebiet nicht gefunden: $netzgebiet_extref\n");
|
||||
}
|
||||
//var_dump($netzgebiet);exit;
|
||||
|
||||
$nutzung = trim($csv[9]);
|
||||
$funktion = trim($csv[20]);
|
||||
if($nutzung != "Greenfield" && $funktion == "Greenfield") {
|
||||
$nutzung = "Greenfield";
|
||||
}
|
||||
|
||||
$unit_count = $csv[10];
|
||||
if(!$unit_count) $unit_count = 1;
|
||||
|
||||
if(!$strasse_hausnummer) continue;
|
||||
|
||||
//echo "strasse: $strasse\n";
|
||||
//echo "strasse_building: $strasse_building\n";
|
||||
|
||||
$strasse_name = "";
|
||||
$hausnummer_name = "";
|
||||
$addresszusatz = "";
|
||||
|
||||
$m = [];
|
||||
// (?:\s+((?:gesch(?:ae|ä)ft|betrieb und wohnungen|paketlogistik|cafe|pavillon|pfarrheim|[^ ]*haus|[^ ]*geb(?:ae|ä)ude|[^ ]*halle)(?:\s+[a-z0-9]+)?))?
|
||||
if(preg_match('/^(\D+)\s+(\d+[a-z0-9\/&#._-]*)(?:\s+((?:gesch(?:ae|ä)ft|betrieb und wohnungen|stg|paketlogistik|cafe|pavillon|pfarrheim|[^ ]*haus|[^ ]*geb(?:ae|ä)ude|[^ ]*halle)(?:\s+[a-z0-9]+)?))?/i', $strasse_hausnummer, $m)) {
|
||||
$strasse_name = trim($m[1]);
|
||||
$hausnummer_name = trim($m[2]);
|
||||
if(array_key_exists(3, $m)) {
|
||||
$addresszusatz = trim($m[3]);
|
||||
}
|
||||
} elseif(preg_match('/^(.+)\s+(\d+[a-z0-9\/&#._-]*)(.+)?/i', $strasse_hausnummer, $m)) {
|
||||
$strasse_name = trim($m[1]);
|
||||
$hausnummer_name = trim($m[2]);
|
||||
if(array_key_exists(3, $m)) {
|
||||
$addresszusatz = trim($m[3]);
|
||||
}
|
||||
} elseif(preg_match('/^(.+)/i', $strasse_hausnummer, $m)) {
|
||||
// ignore GST objects
|
||||
continue;
|
||||
$strasse_name = trim($m[1]);
|
||||
}
|
||||
|
||||
if($strasse_name == "Dr.Karl-Renner-Weg") $strasse_name = "Dr.-Karl-Renner-Weg";
|
||||
if($strasse_name == "Bierbaumer Strasse") $strasse_name = "Bierbaumerstrasse";
|
||||
if($strasse_name == "GST") continue;
|
||||
if(preg_match('/^L\d+/',$strasse_name)) continue;
|
||||
|
||||
/*if($strasse_name == "Hauptstrasse 103 Geschaeft" && $hausnummer_name == "1") {
|
||||
$strasse_name = "Hauptstrasse";
|
||||
$hausnummer_name = "103";
|
||||
$addresszusatz = "Geschaeft 1";
|
||||
}
|
||||
|
||||
if($strasse_name == "Hauptstrasse 131 Stg") {
|
||||
$strasse_name = "Hauptstrasse";
|
||||
$addresszusatz = "Stg $hausnummer_name";
|
||||
$hausnummer_name = "131";
|
||||
}*/
|
||||
|
||||
if(!$strasse_name && !$nutzung == "Greenfield") {
|
||||
die("Unbekanntes Adressformat\n");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
if(!$gem_name || !$plz_name || !$ort_name || !$strasse_name) {
|
||||
die("!! Konnte Adresse nicht parsen\n");
|
||||
}
|
||||
|
||||
if(!$hausnummer_extref) {
|
||||
die("!!! Keine Hausnummer Extref\n");
|
||||
}
|
||||
|
||||
if(!$netzgebiet_extref) {
|
||||
die("!!! Keine Netzgebiet Extref\n");
|
||||
}
|
||||
if($nutzung == "Greenfield") continue;
|
||||
//echo "Netzgebiet extref: \033[1m$netzgebiet_extref\033[0m | Hausnummer extref: \033[1m$hausnummer_extref\033[0m | gem: \033[1m$gem_name\033[0m | plz: \033[1m$plz_name\033[0m | ort: \033[1m$ort_name\033[0m | strasse: \033[1m$strasse_name\033[0m | hausnummer: \033[1m$hausnummer_name\033[0m |";
|
||||
//echo "Zusatz: \033[1m$addresszusatz\033[0m | (\033[1m$nutzung\033[0m)\n";
|
||||
//continue;
|
||||
// find address in AddressDB and update extrefs
|
||||
|
||||
$strasse_name = $db->escape($strasse_name);
|
||||
$hausnummer_name = $db->escape($hausnummer_name);
|
||||
|
||||
$strasse_search = [$strasse_name];
|
||||
|
||||
if(strpos($strasse_name, ' ') !== false) $strasse_search[] = str_replace(' ', '-', $strasse_name);
|
||||
if(strpos($strasse_name, '-') !== false) $strasse_search[] = str_replace('-', ' ', $strasse_name);
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = str_replace('.', '. ', $strasse_name);
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = str_replace('.', '.-', $strasse_name);
|
||||
if(strpos($strasse_name, '. ') !== false) $strasse_search[] = str_replace('. ', '.', $strasse_name);
|
||||
if(strpos($strasse_name, '. ') !== false) $strasse_search[] = str_replace('. ', '.-', $strasse_name);
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = str_replace('.-', '.', $strasse_name);
|
||||
if(strpos($strasse_name, '.') !== false) $strasse_search[] = str_replace('.-', '. ', $strasse_name);
|
||||
|
||||
foreach($strasse_search as $search) {
|
||||
if(strpos($search, 'ß') !== false) $strasse_search[] = str_replace('ß', 'ss', $search);
|
||||
if(strpos($search, 'ä') !== false) $strasse_search[] = str_replace('ä', 'ae', $search);
|
||||
if(strpos($search, 'ö') !== false) $strasse_search[] = str_replace('ö', 'oe', $search);
|
||||
if(strpos($search, 'ü') !== false) $strasse_search[] = str_replace('ü', 'ue', $search);
|
||||
|
||||
if(strpos($search, 'ss') !== false) $strasse_search[] = str_replace('ss', 'ß', $search);
|
||||
if(strpos($search, 'ae') !== false) $strasse_search[] = str_replace('ae', 'ä', $search);
|
||||
if(strpos($search, 'oe') !== false) $strasse_search[] = str_replace('oe', 'ö', $search);
|
||||
if(strpos($search, 'ue') !== false) $strasse_search[] = str_replace('ue', 'ü', $search);
|
||||
}
|
||||
|
||||
|
||||
$sql = "SELECT * FROM view_hausnummer WHERE gemeinde_id = 1 AND strasse IN ('". implode("', '", $strasse_search)."') AND hausnummer='$hausnummer_name'";
|
||||
/*if(preg_match('/^Tobelbader/i',$strasse_name)) {
|
||||
echo "$sql\n";
|
||||
}*/
|
||||
$res = $db->query($sql);
|
||||
|
||||
if(!$db->num_rows($res)) {
|
||||
// adresse nicht gefunden => anlegen
|
||||
|
||||
if($nutzung == "Greenfield") continue;
|
||||
if(!$nutzung || $nutzung == "Transmitting station") continue;
|
||||
|
||||
echo "creating $strasse_name $hausnummer_name $ort_name\n";
|
||||
|
||||
$ort_search = [$ort_name];
|
||||
|
||||
if(strpos($ort_name, 'ß') !== false) $ort_search[] = str_replace('ß', 'ss', $ort_name);
|
||||
if(strpos($ort_name, 'ä') !== false) $ort_search[] = str_replace('ä', 'ae', $ort_name);
|
||||
if(strpos($ort_name, 'ö') !== false) $ort_search[] = str_replace('ö', 'oe', $ort_name);
|
||||
if(strpos($ort_name, 'ü') !== false) $ort_search[] = str_replace('ü', 'ue', $ort_name);
|
||||
|
||||
if(strpos($ort_name, 'ss') !== false) $ort_search[] = str_replace('ss', 'ß', $ort_name);
|
||||
if(strpos($ort_name, 'ae') !== false) $ort_search[] = str_replace('ae', 'ä', $ort_name);
|
||||
if(strpos($ort_name, 'oe') !== false) $ort_search[] = str_replace('oe', 'ö', $ort_name);
|
||||
if(strpos($ort_name, 'ue') !== false) $ort_search[] = str_replace('ue', 'ü', $ort_name);
|
||||
|
||||
$ortschaft = ADBOrtschaftModel::getFirst(['name' => $ort_search]);
|
||||
if(!$ortschaft->id) die("Ortschaft nicht gefunden: $ort_name\n");
|
||||
|
||||
$strasse_id = false;
|
||||
|
||||
$strsql = "SELECT * FROM view_hausnummer WHERE gemeinde_id=1 AND ortschaft IN ('". implode("', '", $ort_search)."') AND strasse IN ('". implode("', '", $strasse_search)."')";
|
||||
//echo "$strsql\n";exit;
|
||||
$strres = $db->query($strsql);
|
||||
if(!$db->num_rows($strres)) {
|
||||
echo("Strasse in adressdb nicht gefunden, wird erstellt: $strsql\n");
|
||||
|
||||
// create strasse
|
||||
|
||||
$strasse_data = [
|
||||
'ortschaft_id' => $ortschaft->id,
|
||||
'gemeinde_id' => 1,
|
||||
'name' => $strasse_name
|
||||
];
|
||||
$strasse = ADBStrasseModel::create($strasse_data);
|
||||
//$strasse_id = $strasse->save();
|
||||
//if(!$strasse_id) die("Cannot create strasse: $strasse_name\n");
|
||||
} else {
|
||||
$data = $db->fetch_object($strres);
|
||||
$strasse_id = $data->strasse_id;
|
||||
}
|
||||
/*
|
||||
if(!$strasse_id) {
|
||||
die("keine strasse_id");
|
||||
}*/
|
||||
/*
|
||||
$plz = ADBPlzModel::getFirst(['plz' => $plz_name]);
|
||||
if(!$plz) die("PLZ nicht gefunden: $plz_name\n");
|
||||
|
||||
$hausnummer_data = [
|
||||
'netzgebiet_id' => $netzgebiet->id,
|
||||
'extref' => $hausnummer_extref,
|
||||
'ortschaft_id' => $ortschaft->id,
|
||||
'plz_id' => $plz->id,
|
||||
'strasse_id' => $strasse_id,
|
||||
'hausnummer' => $hausnummer_name,
|
||||
'zusatz' => $addresszusatz,
|
||||
'gps_lat' => $lat,
|
||||
'gps_long' => $long,
|
||||
'freigabe' => 'voll'
|
||||
];
|
||||
|
||||
//var_dump($hausnummer_data);exit;
|
||||
$hausnummer = ADBHausnummerModel::create($hausnummer_data);
|
||||
$hausnummer_id = $hausnummer->save();
|
||||
|
||||
if(!$hausnummer_id) die("Error creating hausnummer");
|
||||
*/
|
||||
} else {
|
||||
|
||||
$data = $db->fetch_object($res);
|
||||
$hausnummer = new ADBHausnummer($data->hausnummer_id);
|
||||
|
||||
if($hausnummer->netzgebiet_id != $netzgebiet->id) {
|
||||
$hausnummer->netzgebiet_id = $netzgebiet->id;
|
||||
$hausnummer->save();
|
||||
}
|
||||
if($hausnummer->extref != $hausnummer_extref) {
|
||||
$hausnummer->extref = $hausnummer_extref;
|
||||
$hausnummer->save();
|
||||
}
|
||||
$hausnummer->gps_lat = (float)$lat;
|
||||
$hausnummer->gps_long = (float)$long;
|
||||
$hausnummer->freigabe = "voll";
|
||||
$hausnummer->save();
|
||||
|
||||
}
|
||||
/*
|
||||
if($hausnummer) {
|
||||
// create missing wohneinheiten
|
||||
$new_unit_count = 0;
|
||||
$last_unit_tuer = 0;
|
||||
|
||||
$units = ADBWohneinheitModel::search(['hausnummer_id' => $hausnummer->id]);
|
||||
if(count($units)) {
|
||||
foreach($units as $unit) {
|
||||
if($unit->tuer > $last_unit_tuer) {
|
||||
$last_unit_tuer = $unit->tuer;
|
||||
}
|
||||
}
|
||||
}
|
||||
echo $hausnummer->strasse->name." ".$hausnummer->hausnummer."(".$hausnummer->id."): ".count($units)." vorhanden vs. csv ".$unit_count."\n";
|
||||
if(count($units) < $unit_count) {
|
||||
$new_unit_count = $unit_count - count($units);
|
||||
}
|
||||
|
||||
if($new_unit_count && count($units) === 1) {
|
||||
$unit = $units[0];
|
||||
if(!$unit->zusatz && !$unit->tuer) {
|
||||
$unit->tuer = 1;
|
||||
if(!$unit->save()) {
|
||||
die("Couldn't set tuer to 1 (wohneinheit ".$unit->id.")");
|
||||
}
|
||||
$last_unit_tuer = 1;
|
||||
}
|
||||
}
|
||||
|
||||
if($new_unit_count == 1 && $nutzung != "Transmitting station") {
|
||||
// create single wohneinheit
|
||||
echo "Creating single Wohneiheit (".$hausnummer->strasse->name." ".$hausnummer->hausnummer." - hausnummer_id: ".$hausnummer->id.")\n";
|
||||
$unit_data = [
|
||||
'hausnummer_id' => $hausnummer->id,
|
||||
'num' => 1,
|
||||
'nutzung' => "Wohnung"
|
||||
];
|
||||
if($last_unit_tuer) {
|
||||
$unit_data['tuer'] = ++$last_unit_tuer;
|
||||
}
|
||||
$unit = ADBWohneinheitModel::create($unit_data);
|
||||
//var_dump($unit);exit;
|
||||
$unit->save();
|
||||
}
|
||||
|
||||
if($new_unit_count > 1) {
|
||||
echo "Creating $new_unit_count Wohneiheiten (".$hausnummer->strasse->name." ".$hausnummer->hausnummer." - hausnummer_id: ".$hausnummer->id.")\n";
|
||||
for($i = 0; $i < $new_unit_count; $i++) {
|
||||
if($nutzung == "Transmitting station") continue;
|
||||
|
||||
$unit_data = [
|
||||
'hausnummer_id' => $hausnummer->id,
|
||||
'num' => 1,
|
||||
'tuer' => ++$last_unit_tuer,
|
||||
'nutzung' => "Wohnung"
|
||||
];
|
||||
$unit = ADBWohneinheitModel::create($unit_data);
|
||||
|
||||
$unit->save();
|
||||
}
|
||||
//if($hausnummer->id != 1723 && $nutzung != "Transmitting station") { var_dump($unit);exit; }
|
||||
}
|
||||
}*/
|
||||
|
||||
/*
|
||||
|
||||
$data = $db->fetch_object($res);
|
||||
$csv_ort = str_replace(['ß','ä','ö','ü'], ['ss','ae','oe','ue'], $ort_name);
|
||||
$db_ort = str_replace(['ß','ä','ö','ü'], ['ss','ae','oe','ue'], $data->ortschaft);
|
||||
*/
|
||||
// update ortschaft if needed
|
||||
/*
|
||||
if($csv_ort != $db_ort && $nutzung != "Greenfield") {
|
||||
|
||||
if($strasse_name != "Hauptstrasse" && $hausnummer_name != "133") {
|
||||
|
||||
echo "Netzgebiet extref: \033[1m-------\033[0m | Hausnummer extref: \033[1m--------\033[0m | gem: \033[1m$data->gemeinde\033[0m | plz: \033[1m$data->plz\033[0m | ort: \033[1m$db_ort\033[0m | strasse: \033[1m$data->strasse\033[0m | hausnummer: \033[1m$data->hausnummer\033[0m\n";
|
||||
// find ortschaft
|
||||
|
||||
$ortschaft = ADBOrtschaftModel::getFirst(['name' => $ort_name]);
|
||||
if(!$ortschaft) {
|
||||
$ort_data = [];
|
||||
$ort_data['gemeinde_id'] = 1;
|
||||
$ort_data['name'] = $ort_name;
|
||||
$ort_data['plz'] = $plz_name;
|
||||
$ortschaft = ADBOrtschaftModel::create($ort_data);
|
||||
$ortschaft_id = $ortschaft->save();
|
||||
if(!$ortschaft_id) {
|
||||
die("Konnte Ortschaft ($ort_name) nicht erstellen.");
|
||||
}
|
||||
}
|
||||
|
||||
// update ortschaft in hausnummer
|
||||
$hausnummer = new ADBHausnummer($data->hausnummer_id);
|
||||
if(!$hausnummer->id) {
|
||||
die("Hausnummer nicht gefunden für Ort update");
|
||||
}
|
||||
$hausnummer->ortschaft_id = $ortschaft->id;
|
||||
$hausnummer->save();
|
||||
}
|
||||
}*/
|
||||
|
||||
//echo "$data->ortschaft, $data->plz, $data->strasse, $data->hausnummer\n";
|
||||
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user