Modulo:Wikidata/geografio

El Vikipedio, la libera enciklopedio
Dokumentado Dokumentado


Ŝablona programado Diskutoj Lua Testoj Subpaĝoj
Modulo Esperanto English Deutsch

Modulo: Dokumentado


Se vi havas demandon pri ĉi tiu Lua-modulo, tiam vi povas demandi en la diskutejo pri Lua-moduloj. La Intervikiaj ligiloj estu metataj al Vikidatumoj. (Vidu Helpopaĝon pri tio.)
-- 2024-05-05
-- jen helpa modulo por Wikidata, kiu uzas la samajn erarmesaĝojn kiel Wikidata kaj subtenas ID por testoj

-- aliaj moduloj
local wikidata = require ("Modulo:Wikidata")
local kalkuli = require( "Modulo:Math")

local p = {}

-- funkcio nombro por alteco
-- por #invoke
function p.alteco(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	local subf = frame.args["subf"] -- ĉu subfunkcio de alia modulo aŭ ne
	
	return p._alteco(id, showerrors, default, subf)	
end	
	
-- por moduloj	
function p._alteco(id, showerrors, default, subf)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local n = entity:getBestStatements( 'P2044' )
	if (#n == 0) or (n[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
	local x = n[1].mainsnak.datavalue.value.amount
	x=tonumber(x)
	return x
end	

-- por moduloj	
function p._altecoUnuo(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local n = entity:getBestStatements( 'P2044' )
	if (#n == 0) or (n[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
	local x = n[1].mainsnak.datavalue.value.unit
	-- x=tonumber(x)
	local y = string.sub(x,32)
	if y == "Q828224" then			-- kilometroj
		x = "km"
	elseif y == "Q11573" then		-- metroj
		x = "m"		
	elseif y == "Q174728" then		-- centimetroj
		x = "cm"			
	elseif y == "Q253276" then		-- mejloj
		x = "mi"
	elseif y == "Q3710" then		-- futoj
		x = "ft"
	else
		x = "km" 					-- kilometroj
	end
	return x
end

-- por moduloj
function p._altecoM(alteco, unuo)
	local r
	
	if unuo == "m" then
		r = alteco
	elseif unuo == "km" then	
		r = alteco * 1000
	elseif unuo == "cm" then
		r = alteco / 100
	elseif unuo == "mi" then
		r = alteco * 1609.344
	elseif unuo == "ft" then
		r = alteco * 0.3048
	else			-- supozas, ke temas pri metroj
		r = alteco
	end
	
	return r
end	

-- funkcioj pri areo kaj ties mezurunuoj, aldone kun transkalkuladoj al km² kaj ha (por informkestoj)
-- funkcio nombro por areo
-- por #invoke
function p.areo(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	local subf = frame.args["subf"] -- ĉu subfunkcio de alia modulo aŭ ne
	
	return p._areo(id, showerrors, default, subf)
end	
	
-- por moduloj	
function p._areo(id, showerrors, default, subf)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local n = entity:getBestStatements( 'P2046' )
	if (#n == 0) or (n[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
	local x = n[1].mainsnak.datavalue.value.amount
	x=tonumber(x)
	if not subf then
		x= string.gsub(x,"%.",",") -- ŝanĝo de angla punkto al esperanta komo
	end
	return x
end

-- funkcio nombro por unuo de areo
-- por #invoke
function p.areoUnuo(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._areoUnuo(id, showerrors, default)
end	
	
-- por moduloj	
function p._areoUnuo(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local n = entity:getBestStatements( 'P2046' )
	if (#n == 0) or (n[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
	local x = n[1].mainsnak.datavalue.value.unit
	-- x=tonumber(x)
	local y = string.sub(x,32)
	if y == "Q71226" then			-- kvadrataj kilometroj
		x = "km²"
	elseif y == "Q35852" then		-- hektaro
		x = "ha" -- hektaro		
	elseif y == "Q25343" then		-- kvadrataj metroj
		x = "m²"		
	elseif y == "Q2486298" then		-- kvadrataj centimetroj
		x = "cm²"			
	elseif y == "Q232291" then		-- kvadrataj mejloj
		x = "mi²"
	else
		x = "km²" 					-- kvadrataj kilometroj
	end
	return x
end

-- transkalkulas al kvadrataj kilometroj
-- por #invoke
function p.areoKM2(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	local mode = frame.args["mode"]
	local rondumo = frame.args["round"]
	
	return p._areoKM2(id, showerrors, default, mode, rondumo)	
end

-- por moduloj	
function p._areoKM2(id, showerrors, default, mode, rondumo)	
	local a = p.areo({ args = { id = id, showerrors = showerrors, default=default, subf = "jes"  } })
	local u = p.areoUnuo({ args = { id = id, showerrors = showerrors, default=default  } })	
	local ru = "[[Kvadrata kilometro|km²]]"
	local rondumo = tonumber(rondumo)
	if rondumo == nil or rondumo == "" then
		rondumo = 0
	end	
	
	if a ~= nil and u ~= nil then
		local r = 1
		if u == "km²" then         			-- jam estas km²
			r = a
		elseif u == "ha" then				-- el hektaroj al km²     
			r = a / 100		
			r = kalkuli._round(r,rondumo)			
		elseif u == "m²" then 				-- el metroj al km²
			r = a / 1e6
			r = kalkuli._round(r,rondumo)
		elseif u == "cm²" then				-- el cm² al km²
			r = a / 1e10
			r = kalkuli._round(r,rondumo)
		elseif u == "mi²" then				-- el mi² (kvadrataj mejloj) al km²
			r = a * 2.589988110336
			r = kalkuli._round(r, rondumo)
		else								-- taksi kiel km²
			r = a
		end	
		if mode == "subfunkcio" then
			return r, unuo					-- en subfunkcio la mezurunuo devas esti transdonata aparte, por ke kalkulado eblu
		else	
			r= string.gsub(r,"%.",",")     		-- ŝanĝo de angla punkto al esperanta komo			
			return r .. " " .. ru			-- eldono kun unuo
		end
		
	else
		return "neniuj valoroj"
	end	
end	

-- transkalkulas al hektaroj
-- #invoke
function p.areoHA(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	local mode = frame.args["mode"]	
	local rondumo = frame.args["round"]	
	
	return p._areoHA(id, showerrors, default, mode, rondumo)	
end	
	
-- por moduloj	
function p._areoHA(id, showerrors, default, mode, rondumo)	
	local a = p.areo({ args = { id = id, showerrors = showerrors, default=default, subf = "jes"  } })
	local u = p.areoUnuo({ args = { id = id, showerrors = showerrors, default=default  } })	
	local ru = "[[Hektaro|ha]]"
	local rondumo = tonumber(rondumo)
	if rondumo == nil or rondumo == "" then
		rondumo = 0
	end	
	
	if a ~= nil and u ~= nil then
		local r = 1
		if u == "km²" then					-- el km² al hektaroj
			r = a * 100
			r = kalkuli._round(r,rondumo)
		elseif u == "ha" then				-- jam hektaroj      
			r = a 			
		elseif u == "m²" then				-- el metroj al hektaroj
			r = a / 1e4
			r = kalkuli._round(r,rondumo)
		elseif u == "cm²" then				-- el cm² al hektaroj
			r = a / 1e8
			r = kalkuli._round(r,rondumo)
		elseif u == "mi²" then				-- el mi² (kvadrataj mejloj) al ha
			r = a * 258.988110336
			r = kalkuli._round(r, rondumo)			
		else								-- taksi kiel km² kaj kalkuli al ha
			r = a * 100
			r = kalkuli._round(r,rondumo)			
		end	
		if mode == "subfunkcio" then
			return r, unuo					-- en subfunkcio la mezurunuo devas esti transdonata aparte, por ke kalkulado eblu
		else	
			r= string.gsub(r,"%.",",")     		-- ŝanĝo de angla punkto al esperanta komo			
			return r .. " " .. ru			-- eldono kun unuo
		end	
	else
		return "neniuj valoroj"
	end	
end	


-- funkcio por legi la nombro da subdividoj (p150)
-- por #invoke
function p.NombroSubdividoj(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._NombroSubdividoj(id, showerrors, default)	
end	
	
-- por moduloj	
function p._NombroSubdividoj(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local subdividoj = entity:getBestStatements( 'P150' )
	if (#subdividoj == 0) then
		return nil
	end	
	return #subdividoj
end	

-- Listo de la subdividoj
-- por #invoke
function p.Subdividoj(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._Subdividoj(id, showerrors, default)	
end	

-- por moduloj
function p._Subdividoj(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local subdividoj = entity:getBestStatements( 'P150' )
	local n=#subdividoj
  	if n == 0 then return nil end
		
	 local q=''
	 local t={{}}

-- kreigo de la listo
for i=1,n do
            q= 'Q' .. subdividoj[i].mainsnak.datavalue.value["numeric-id"]
			local x=mw.wikibase.label(q)
	        if x ~= nil then
				local z=mw.wikibase.sitelink(q) or 'ne konata'
				if x~=z and z~='ne konata' then x=z..'|'..x end
				t[i]=x
			else
			    t[i] =  ':d:'..q..''
			end --x ~= nil
 	end -- for
 
 -- klasifikigo de la listo
 	table.sort(t)
 	local y='[['..t[1]..']]'
   	for i=2,n-1  do y=y .. ', [[' .. t[i] .. ']]'	end
   	y=y .. ' kaj [[' .. t [n] .. ']]'
return y
end--Subdividoj

-- Legi la administran unuon de la administra unuo
-- por #invoke
function p.administraUnuo(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._administraUnuo(id, showerrors, default)
end	
	
-- por moduloj	
function p._administraUnuo(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local unuo= entity:getBestStatements( 'P131' ) 
	if (#unuo == 0) or (unuo[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    q= 'Q' .. unuo[1].mainsnak. datavalue.value["numeric-id"] 
	local x=mw.wikibase.label(q)
	local z=mw.wikibase.sitelink(q) or 'ne konata'
	if x~=z and z~='ne konata' then x='[['.. z..'|'..x..']]' end
	return x
end--AdministraUnuo

-- aldonoj de 2024-04-26, 2024-04-27

-- redonu la latitudon de objekto
-- por #invoke
function p.latitudo(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._latitudo(id, showerrors, default)	
end	

-- por moduloj	
function p._latitudo(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end	
    local koord= entity:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local lat = koord[1].mainsnak. datavalue.value["latitude"] 
    if lat ~= nil then 
    	return lat
    else 
    	return nil
    end	
	
end	

-- redonu longitudon de objekto
-- por #invoke
function p.longitudo(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._longitudo(id, showerrors, default)
end	
	
-- por moduloj	
function p._longitudo(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end	
    local koord= entity:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local long = koord[1].mainsnak. datavalue.value["longitude"] 
    if long ~= nil then 
    	return long
    else 
    	return nil
    end	
	
end	



-- redonu la latitudon de plej alta punkto
-- por #invoke
function p.plejaltalat(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._plejaltalat(id, showerrors, default)
end	
	
-- por moduloj	
function p._plejaltalat(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local plejalta= entity:getBestStatements( 'P610' ) 
	if (#plejalta == 0) or (plejalta[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    q= 'Q' .. plejalta[1].mainsnak. datavalue.value["numeric-id"] 
    -- get wikidata entity
	local entity2 = mw.wikibase.getEntity(q)
	if not entity2 then return nil end
    local koord= entity2:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local lat = koord[1].mainsnak. datavalue.value["latitude"] 
    if lat ~= nil then 
    	return lat
    else 
    	return nil
    end

end

-- redonu la longitudon de plej alta punkto
-- por #invoke
function p.plejaltalong(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]

	return 	p._plejaltalong(id, showerrors, default)
end	

-- por moduloj 
function p._plejaltalong(id, showerrors, default)
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local plejalta= entity:getBestStatements( 'P610' ) 
	if (#plejalta == 0) or (plejalta[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    q= 'Q' .. plejalta[1].mainsnak. datavalue.value["numeric-id"] 
    -- get wikidata entity
	local entity2 = mw.wikibase.getEntity(q)
	if not entity2 then return nil end
    local koord= entity2:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local long = koord[1].mainsnak. datavalue.value["longitude"] 
    if long ~= nil then 
    	return long
    else 
    	return nil
    end    
    
end


-- redonu la latitudon de plej malalta punkto
-- por #invoke
function p.plejmalaltalat(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._plejmalaltalat(id, showerrors, default)
end	

-- por moduloj	
function p._plejmalaltalat(id, showerrors, default)
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local plejalta= entity:getBestStatements( 'P1589' ) 
	if (#plejalta == 0) or (plejalta[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    q= 'Q' .. plejalta[1].mainsnak. datavalue.value["numeric-id"] 
    -- get wikidata entity
	local entity2 = mw.wikibase.getEntity(q)
	if not entity2 then return nil end
    local koord= entity2:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local lat = koord[1].mainsnak. datavalue.value["latitude"] 
    if lat ~= nil then 
    	return lat
    else 
    	return nil
    end

end

-- redonu la longitudon de plej malalta punkto
-- por #invoke
function p.plejmalaltalong(frame)
	local id = frame.args["id"]	
	local showerrors = frame.args["showerrors"]
	local default = frame.args["default"]
	
	return p._plejmalaltalong(id, showerrors, default)
end	

-- por moduloj	
function p._plejmalaltalong(id, showerrors, default)	
	if default then showerrors = nil end

	-- get wikidata entity
	local entity = mw.wikibase.getEntity(id)
	if not entity then
		if showerrors then return wikidata.printError("entity-not-found") else return default end
	end
	local plejalta= entity:getBestStatements( 'P1589' ) 
	if (#plejalta == 0) or (plejalta[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    q= 'Q' .. plejalta[1].mainsnak. datavalue.value["numeric-id"] 
    -- get wikidata entity
	local entity2 = mw.wikibase.getEntity(q)
	if not entity2 then return nil end
    local koord= entity2:getBestStatements( 'P625' ) 
    if (#koord == 0) or (koord[1].mainsnak.snaktype ~= "value") then
		return nil
	end	
    local long = koord[1].mainsnak. datavalue.value["longitude"] 
    if long ~= nil then 
    	return long
    else 
    	return nil
    end    
    
end

return p