Modul:Adresse: Unterschied zwischen den Versionen

Aus FürthWiki

(fix)
(Adresse() subobject optimiert)
 
(8 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
local p = {}
local p = {}


local com = require("Modul:Common")
local dev = require("Modul:Development")
local dev = require("Modul:Development")
local str = require("Modul:String")
local str = require("Modul:String")
local smw = require("Modul:SMW")
local geo = require("Modul:Geo")
local geo = require("Modul:Geo")
local wik = require("Modul:Wiki")
local wik = require("Modul:Wiki")
local kal = require("Modul:Kalender")


function p.Adresse(frame)
function p.Adresse(frame)
-- mw.log("Adresse(frame)")
-- mw.logObject(frame, "Adresse(frame)")
-- mw.logObject(frame)
-- Konsolenzeile zum Debuggen:
-- Konsolenzeile zum Debuggen:
-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Schwabacher Straße", ["Hausnummer"]="12",["AdresseVon"]="b", ["AdresseBis"]="c",  ["Kommentar"]="f"}}
-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Schwabacher Straße", ["Hausnummer"]="12",["AdresseVon"]="2020-03-04", ["AdresseBis"]="2021-05-06",  ["Kommentar"]="f"}}
-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Fichtenstraße", ["Hausnummer"]="44",["AdresseVon"]="b", ["AdresseBis"]="c",  ["Kommentar"]="f"}}
-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Fichtenstraße", ["Hausnummer"]="44",["AdresseVon"]="2020-03-04", ["AdresseBis"]="2021-05-06",  ["Kommentar"]="f"}}
-- =p.Adresse{pargs={["Adressart"]="Geschäftsanschrift",["AdresseVon"]="1961",["AdresseBis"]="2024/07/01",["Straße"]="Würzburger Straße",["Hausnummer"]="454"}}
local t = ""
local t = ""
local fail = false
local fail = false
local _, pargs = dev.GetFrameAndParentArgs(frame)
local frame, pargs = dev.GetFrameAndParentArgs(frame)
local attr, attr_empty = wik.getArgs(pargs, {"Adressart", "AdresseVon", "AdresseBis", "Straße", "Hausnummer", "Kommentar"})
-- nur benötigte Attribut-Werte aus Formular (ParentArgs) herausholen
local attr = {}
local attr_empty = true
for _, a in ipairs{"Adressart", "AdresseVon", "AdresseBis", "Straße", "Hausnummer", "Kommentar"} do
local v = pargs[a] or ""
if v ~= "" then
attr[a] = v
attr_empty = false
end
end


-- subobject-Name
if attr_empty then -- Überhaupt Parameter übergeben?
local subobject = {}
table.insert(subobject, attr["Adressart"])
table.insert(subobject, attr["Straße"])
table.insert(subobject, attr["Hausnummer"])
subobject = table.concat(subobject, " ")
if subobject == "" then -- subobject-Name fehlerhaft?
fail = true
fail = true
else
else
 
-- subobject-Name
-- Straße/Hausnummer auswerten
local subobject = {"Adresse"}
if attr["Straße"] ~= nil then
table.insert(subobject, attr["Adressart"])
if attr["Hausnummer"] ~= nil then
table.insert(subobject, attr["Straße"])
attr["StraßeHnr"] = attr["Straße"] .. " " .. attr["Hausnummer"]
table.insert(subobject, attr["Hausnummer"])
else
table.insert(subobject, attr["Kommentar"])
attr["StraßeHnr"] = attr["Straße"]
subobject = table.concat(subobject, " ")
subobject = smw.subobjectIdCleaner(subobject)
if subobject == "" then -- subobject-Name fehlerhaft?
fail = true
else
-- SubObjektTyp setzen
attr["SubObjektTyp"] = "Adresse"
-- Straße/Hausnummer auswerten
if attr["Straße"] ~= nil then
if attr["Hausnummer"] ~= nil then
attr["StraßeHnr"] = attr["Straße"] .. " " .. attr["Hausnummer"]
else
attr["StraßeHnr"] = attr["Straße"]
end
elseif attr["Hausnummer"] ~= nil then
fail = true -- Fehler Hausnummer ohne Straße
end
end
elseif attr["Hausnummer"] ~= nil then
-- Postleitzahl ermitteln
fail = true -- Fehler Hausnummer ohne Straße
if attr["Straße"] ~= nil then
end
local PLZ = geo.getPLZ(attr["Straße"], attr["Hausnummer"])
 
if PLZ ~= "" then
-- Postleitzahl ermitteln
attr["PLZ"] = PLZ
if attr["Straße"] ~= nil then
end
local PLZ = geo.getPLZ(attr["Straße"], attr["Hausnummer"])
if PLZ ~= "" then
attr["PLZ"] = PLZ
end
end
end
-- VonObjekt erstellen
if attr["StraßeHnr"] ~= nil then
-- VonObjekt erstellen
if wik.pageExists(attr["StraßeHnr"]) then
if attr["StraßeHnr"] ~= nil then
attr["VonObjekt"] = attr["StraßeHnr"]
if wik.pageExists(attr["StraßeHnr"]) then
else
attr["VonObjekt"] = attr["StraßeHnr"]
-- Seite mit passender StraßeHnr suchen
else
local ask_result = mw.smw.ask("[[:+]][[Kategorie:Gebäude]][[StraßeHnr::" .. attr["StraßeHnr"] .. "]]|?#-|limit=1")
-- Seite mit passender StraßeHnr suchen
if ask_result ~= nil and #ask_result > 0 then
local ask_result = mw.smw.ask("[[:+]][[Kategorie:Gebäude]][[StraßeHnr::" .. attr["StraßeHnr"] .. "]]|?#-|limit=1")
attr["VonObjekt"] = ask_result[1][1]
if ask_result ~= nil and #ask_result > 0 then
end
attr["VonObjekt"] = ask_result[1][1]
end
end
end
end
end
-- subobject setzen
mw.smw.subobject(attr, subobject)
-- subobject zusammenbauen
-- Plausibilitätsprüfung von/bis
if not attr_empty then
if attr["AdresseVon"] ~= nil and attr["AdresseBis"] ~= nil and
t = t .. "{{#subobject:" .. subobject
  p.formDate2CompareIndex(attr["AdresseVon"], "von") > p.formDate2CompareIndex(attr["AdresseBis"], "bis") then
for a, v in pairs(attr) do
  fail = true
t = t .. "|" .. a .. "=" .. v
end
end
t = t .. "}}"
end -- Ende if subobject-Name fehlerhaft?
end
end -- Ende if not attr_empty
-- Wartungsmeldung Adresse fehlerhaft
-- Plausibilitätsprüfung von/bis
if attr["AdresseVon"] ~= nil and attr["AdresseBis"] ~= nil and
  p.smwDate2CompareIndex(attr["AdresseVon"], "von") > p.smwDate2CompareIndex(attr["AdresseBis"], "bis") then
  fail = true
end
 
end -- Ende if subobject-Name fehlerhaft?
 
-- Kategorie:Fehlerhafte Adresse
if fail then
if fail then
t = t .. "[[Kategorie:Fehlerhafte Adresse]]"
mw.smw.set{["Wartungsmeldung"]="Adresse fehlerhaft"}
end
end
 
-- mw.logObject(t, "t")
-- mw.log("t = " .. t)
t = frame:preprocess(t)
return t
return t
end
end


function p.smwDate2CompareIndex(date, vonbis)
function p.formDate2CompareIndex(date, vonbis)
-- mw.log("smwDate2CompareIndex(" .. date .. ")")
-- mw.log("formDate2CompareIndex(" .. date .. ")")
-- Datum in Index wandeln
-- Datum in Index wandeln
-- Bsp.: 23 Apr. 1989 => 19890423
-- Bsp.: 23 April 1989 => 19890423
-- Konsolenzeile zum Debuggen:
-- Konsolenzeile zum Debuggen:
-- =p.smwDate2CompareIndex("2000","von")
-- =p.formDate2CompareIndex("2000","von")
-- =p.smwDate2CompareIndex("2000","bis")
-- =p.formDate2CompareIndex("2000","bis")
-- =p.smwDate2CompareIndex("Februar 2000","von")
-- =p.formDate2CompareIndex("Februar 2000","von")
-- =p.smwDate2CompareIndex("Februar 2000","bis")
-- =p.formDate2CompareIndex("Februar 2000","bis")
-- =p.smwDate2CompareIndex("3. Februar 2000","von")
-- =p.formDate2CompareIndex("2000/02/03","von")
-- =p.smwDate2CompareIndex("3. Februar 2000","bis")
-- =p.formDate2CompareIndex("2000/02/03","bis")
local index = ""
local index = ""
local date=str.split2(date, " ")
local date = str.split2(date, "/")
if #date == 1 then -- nur Jahr vorhanden
if #date == 3 then -- komplettes Datum vorhanden
index = tostring(date[1])
index = tostring(date[1]) .. tostring(date[2]) .. tostring(date[3])
if vonbis == "von" then
else
index = index .. "0101"
date = str.split2(date[1], " ")
else
if #date == 1 then -- nur Jahr vorhanden
index = index .. "1231"
index = tostring(date[1])
end
if vonbis == "von" then
elseif #date == 2 then -- nur Monat + Jahr vorhanden
index = index .. "0101"
index = tostring(date[2]) .. string.format("%02d", com.getMonthnr(date[1]))
else
if vonbis == "von" then
index = index .. "1231"
index = index .. "01"
end
else
elseif #date == 2 then -- nur Monat + Jahr vorhanden
index = index .. "31"
index = tostring(date[2]) .. string.format("%02d", kal.month_numbers[date[1]])
if vonbis == "von" then
index = index .. "01"
else
index = index .. "31"
end
end
end
elseif #date == 3 then -- komplettes Datum vorhanden
index = tostring(date[3]) .. string.format("%02d",com.getMonthnr(date[2])) .. string.format("%02d", tonumber(string.match(date[1], "%d*")))
end
end
index = tonumber(index) or 0
index = tonumber(index) or 0

Aktuelle Version vom 15. Januar 2026, 19:02 Uhr

Dieses Modul setzt die Subobjekte von Adressen.

Unterseiten

Siehe auch


local p = {}

local dev = require("Modul:Development")
local str = require("Modul:String")
local smw = require("Modul:SMW")
local geo = require("Modul:Geo")
local wik = require("Modul:Wiki")
local kal = require("Modul:Kalender")

function p.Adresse(frame)
--	mw.logObject(frame, "Adresse(frame)")
	-- Konsolenzeile zum Debuggen:
	-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Schwabacher Straße", ["Hausnummer"]="12",["AdresseVon"]="2020-03-04", ["AdresseBis"]="2021-05-06",  ["Kommentar"]="f"}}
	-- =p.Adresse{pargs={["Adressart"]="Wohnung", ["Straße"]="Fichtenstraße", ["Hausnummer"]="44",["AdresseVon"]="2020-03-04", ["AdresseBis"]="2021-05-06",  ["Kommentar"]="f"}}
	-- =p.Adresse{pargs={["Adressart"]="Geschäftsanschrift",["AdresseVon"]="1961",["AdresseBis"]="2024/07/01",["Straße"]="Würzburger Straße",["Hausnummer"]="454"}}
	local t = ""
	local fail = false
	local frame, pargs = dev.GetFrameAndParentArgs(frame)
	local attr, attr_empty = wik.getArgs(pargs, {"Adressart", "AdresseVon", "AdresseBis", "Straße", "Hausnummer", "Kommentar"})

	if attr_empty then															-- Überhaupt Parameter übergeben?
		fail = true
	else
		-- subobject-Name
		local subobject = {"Adresse"}
		table.insert(subobject, attr["Adressart"])
		table.insert(subobject, attr["Straße"])
		table.insert(subobject, attr["Hausnummer"])
		table.insert(subobject, attr["Kommentar"])
		subobject = table.concat(subobject, " ")
		subobject = smw.subobjectIdCleaner(subobject)
		if subobject == "" then													-- subobject-Name fehlerhaft?
			fail = true
		else
			-- SubObjektTyp setzen
			attr["SubObjektTyp"] = "Adresse"
			-- Straße/Hausnummer auswerten
			if attr["Straße"] ~= nil then
				if attr["Hausnummer"] ~= nil then
					attr["StraßeHnr"] = attr["Straße"] .. " " .. attr["Hausnummer"]
				else
					attr["StraßeHnr"] = attr["Straße"]
				end
			elseif attr["Hausnummer"] ~= nil then
				fail = true														-- Fehler Hausnummer ohne Straße
			end
			-- Postleitzahl ermitteln
			if attr["Straße"] ~= nil then
				local PLZ = geo.getPLZ(attr["Straße"], attr["Hausnummer"])
				if PLZ ~= "" then
					attr["PLZ"] = PLZ
				end
			end
			-- VonObjekt erstellen
			if attr["StraßeHnr"] ~= nil then
				if wik.pageExists(attr["StraßeHnr"]) then
					attr["VonObjekt"] = attr["StraßeHnr"]
				else
					-- Seite mit passender StraßeHnr suchen
					local ask_result = mw.smw.ask("[[:+]][[Kategorie:Gebäude]][[StraßeHnr::" .. attr["StraßeHnr"] .. "]]|?#-|limit=1")
					if ask_result ~= nil and #ask_result > 0 then
						attr["VonObjekt"] = ask_result[1][1]
					end
				end
			end
			-- subobject setzen
			mw.smw.subobject(attr, subobject)
			-- Plausibilitätsprüfung von/bis
			if attr["AdresseVon"] ~= nil and attr["AdresseBis"] ~= nil and
			   p.formDate2CompareIndex(attr["AdresseVon"], "von") > p.formDate2CompareIndex(attr["AdresseBis"], "bis") then
			   	fail = true
			end
		end																		-- Ende if subobject-Name fehlerhaft?
	end																			-- Ende if not attr_empty
	-- Wartungsmeldung Adresse fehlerhaft
	if fail then
		mw.smw.set{["Wartungsmeldung"]="Adresse fehlerhaft"}
	end
--	mw.logObject(t, "t")
	return t
end

function p.formDate2CompareIndex(date, vonbis)
--	mw.log("formDate2CompareIndex(" .. date .. ")")
	-- Datum in Index wandeln
	-- Bsp.: 23 April 1989 => 19890423
	-- Konsolenzeile zum Debuggen:
	-- =p.formDate2CompareIndex("2000","von")
	-- =p.formDate2CompareIndex("2000","bis")
	-- =p.formDate2CompareIndex("Februar 2000","von")
	-- =p.formDate2CompareIndex("Februar 2000","bis")
	-- =p.formDate2CompareIndex("2000/02/03","von")
	-- =p.formDate2CompareIndex("2000/02/03","bis")
	local index = ""
	local date = str.split2(date, "/")
	if #date == 3 then															-- komplettes Datum vorhanden
		index = tostring(date[1]) .. tostring(date[2]) .. tostring(date[3])
	else
		date = str.split2(date[1], " ")
		if #date == 1 then														-- nur Jahr vorhanden
			index = tostring(date[1])
			if vonbis == "von" then
				index = index .. "0101"
			else
				index = index .. "1231"
			end
		elseif #date == 2 then													-- nur Monat + Jahr vorhanden
			index = tostring(date[2]) .. string.format("%02d", kal.month_numbers[date[1]])
			if vonbis == "von" then
				index = index .. "01"
			else
				index = index .. "31"
			end
		end
	end
	index = tonumber(index) or 0
--	mw.log("index = " .. tostring(index))
	return index
end

return p