Added salescluster to addressdb and preorder

This commit is contained in:
Frank Schubert
2022-10-04 21:42:00 +02:00
parent 9db6ae59c3
commit 9b3335c820
17 changed files with 552 additions and 87 deletions

View File

@@ -13,7 +13,7 @@ require_once(LIBDIR."/mvcfronk/mfBase/mfBaseController.php");
$me = new User(1);
$filename = BASEDIR."/scripts/import/60670-1u2__Premstaetten_FTTxLocations.csv";
$filename = BASEDIR."/scripts/import/premstaetten_buildings.csv";
$db = FronkDB::singleton(ADDRESSDB_DBHOST, ADDRESSDB_DBUSER, ADDRESSDB_DBPASS, ADDRESSDB_DBNAME);
$log = mfLoghandler::singleton();
@@ -23,31 +23,34 @@ $input = fopen($filename, "r");
$h_extrefs = [];
$i = 0;
while($csv = fgetcsv($input, 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[1]);
$gem_name = trim($csv[0]);
$gem_kz = trim($csv[17]);
$gem_name = trim($csv[18]);
//$ort_kz = trim($csv[2]);
$plz_name = trim($csv[3]);
$ort_name = trim($csv[4]);
$strasse_hausnummer = trim($csv[5]);
$hausnummer_extref = trim($csv[35]);
$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 = trim($csv[17]);
$long = trim($csv[18]);
$lat = str_replace(",",".",trim($csv[7]));
$long = str_replace(",",".",trim($csv[8]));
$netzgebiet_extref = trim($csv[26]);
$netzgebiet_extref = trim($csv[14]);
if(!$netzgebiet_extref) continue;
$netzgebiet = new ADBNetzgebiet();
$netzgebiet->loadByExtref($netzgebiet_extref);
if(!$netzgebiet->id) {
@@ -55,12 +58,15 @@ while($csv = fgetcsv($input, 0, ",")) {
}
//var_dump($netzgebiet);exit;
$nutzung = trim($csv[7]);
$funktion = trim($csv[9]);
$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";
@@ -75,11 +81,15 @@ while($csv = fgetcsv($input, 0, ",")) {
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]);
$addresszusatz = trim($m[3]);
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]);
$addresszusatz = trim($m[3]);
if(array_key_exists(3, $m)) {
$addresszusatz = trim($m[3]);
}
} elseif(preg_match('/^(.+)/i', $strasse_hausnummer, $m)) {
// ignore GST objects
continue;
@@ -110,8 +120,6 @@ while($csv = fgetcsv($input, 0, ",")) {
if(!$gem_name || !$plz_name || !$ort_name || !$strasse_name) {
die("!! Konnte Adresse nicht parsen\n");
}
@@ -188,10 +196,10 @@ while($csv = fgetcsv($input, 0, ",")) {
$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;
//echo "$strsql\n";exit;
$strres = $db->query($strsql);
if(!$db->num_rows($strres)) {
echo("Strasse in adressdb nicht gefunden: $strsql\n");
echo("Strasse in adressdb nicht gefunden, wird erstellt: $strsql\n");
// create strasse
@@ -201,17 +209,17 @@ while($csv = fgetcsv($input, 0, ",")) {
'name' => $strasse_name
];
$strasse = ADBStrasseModel::create($strasse_data);
$strasse_id = $strasse->save();
if(!$strasse_id) die("Cannot create strasse: $strasse_name\n");
//$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");
@@ -224,7 +232,8 @@ while($csv = fgetcsv($input, 0, ",")) {
'hausnummer' => $hausnummer_name,
'zusatz' => $addresszusatz,
'gps_lat' => $lat,
'gps_long' => $long
'gps_long' => $long,
'freigabe' => 'voll'
];
//var_dump($hausnummer_data);exit;
@@ -232,8 +241,9 @@ while($csv = fgetcsv($input, 0, ",")) {
$hausnummer_id = $hausnummer->save();
if(!$hausnummer_id) die("Error creating hausnummer");
*/
} else {
$data = $db->fetch_object($res);
$hausnummer = new ADBHausnummer($data->hausnummer_id);
@@ -245,20 +255,85 @@ while($csv = fgetcsv($input, 0, ",")) {
$hausnummer->extref = $hausnummer_extref;
$hausnummer->save();
}
$hausnummer->gps_lat = $lat;
$hausnummer->gps_long = $long;
$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") {
@@ -266,7 +341,7 @@ while($csv = fgetcsv($input, 0, ",")) {
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]);
$ortschaft = ADBOrtschaftModel::getFirst(['name' => $ort_name]);
if(!$ortschaft) {
$ort_data = [];
$ort_data['gemeinde_id'] = 1;
@@ -285,9 +360,9 @@ while($csv = fgetcsv($input, 0, ",")) {
die("Hausnummer nicht gefunden für Ort update");
}
$hausnummer->ortschaft_id = $ortschaft->id;
$hausnummer->save();*/
$hausnummer->save();
}
}
}*/
//echo "$data->ortschaft, $data->plz, $data->strasse, $data->hausnummer\n";