„Modul:CactaceaeTaxonok” változatai közötti eltérés
Megjelenés
Nincs szerkesztési összefoglaló Címke: Visszaállítva |
Nincs szerkesztési összefoglaló Címke: Kézi visszaállítás |
||
| 1. sor: | 1. sor: | ||
local p = {} | local p = {} | ||
-- Unicode-biztos | -- Segédfüggvény a szimbólumok és HTML lista kezeléséhez (Unicode-biztos) | ||
local function formazSzinonimak(szoveg) | local function formazSzinonimak(szoveg) | ||
if not szoveg or szoveg == "" then return "" end | if not szoveg or szoveg == "" then return "" end | ||
-- 1. Felesleges karakterek törlése (Unicode-biztosan) | |||
local tiszta = mw.ustring.gsub(szoveg, "[đ÷]", "") | local tiszta = mw.ustring.gsub(szoveg, "[đ÷]", "") | ||
tiszta = mw.ustring.gsub(tiszta, "¤+", "") | tiszta = mw.ustring.gsub(tiszta, "¤+", "") | ||
-- | -- 2. Kacsacsőrös jelek egyszerűsítése (maradnak az adott sorban) | ||
tiszta = mw.ustring.gsub(tiszta, ">−", "−") | tiszta = mw.ustring.gsub(tiszta, ">−", "−") | ||
tiszta = mw.ustring.gsub(tiszta, ">≡", "≡") | tiszta = mw.ustring.gsub(tiszta, ">≡", "≡") | ||
tiszta = mw.ustring.gsub(tiszta, ">=", "=") | tiszta = mw.ustring.gsub(tiszta, ">=", "=") | ||
-- | -- 3. Új listapont jelölők átalakítása (ideiglenes elválasztó: | ) | ||
-- Csak a duplázott jeleknél darabolunk | |||
tiszta = mw.ustring.gsub(tiszta, "≡≡", "|≡") | tiszta = mw.ustring.gsub(tiszta, "≡≡", "|≡") | ||
tiszta = mw.ustring.gsub(tiszta, "==", "|=") | tiszta = mw.ustring.gsub(tiszta, "==", "|=") | ||
tiszta = mw.ustring.gsub(tiszta, "−−", "|−") | tiszta = mw.ustring.gsub(tiszta, "−−", "|−") | ||
tiszta = mw.ustring.gsub(tiszta, " | -- A sima kötőjeleket külön kezeljük, mert a Lua mintában a - speciális karakter | ||
tiszta = mw.ustring.gsub(tiszta, "%-%-", "|−") | |||
-- 4. HTML lista építése | |||
local lista_elemek = {} | local lista_elemek = {} | ||
-- Darabolás az mw.text.gsplit-tel (ez biztonságosabb) | |||
for resz in mw.text.gsplit(tiszta, "|", true) do | for resz in mw.text.gsplit(tiszta, "|", true) do | ||
local tiszta_resz = mw.text.trim(resz) | local tiszta_resz = mw.text.trim(resz) | ||
if tiszta_resz ~= "" then | if tiszta_resz ~= "" then | ||
-- Botanikai nevek dőltetése a részen belül | |||
local szavak = {} | local szavak = {} | ||
for szo in mw.ustring.gmatch(tiszta_resz, "%S+") do | for szo in mw.ustring.gmatch(tiszta_resz, "%S+") do | ||
-- Ha a szó szimbólumot, vesszőt tartalmaz vagy technikai rövidítés, marad álló | |||
if mw.ustring.find(szo, "[≡=−,]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then | if mw.ustring.find(szo, "[≡=−,]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then | ||
table.insert(szavak, szo) | table.insert(szavak, szo) | ||
| 31. sor: | 39. sor: | ||
end | end | ||
end | end | ||
table.insert(lista_elemek, "<li>" .. | |||
local kesz_elem = table.concat(szavak, " ") | |||
table.insert(lista_elemek, "<li>" .. kesz_elem .. "</li>") | |||
end | end | ||
end | end | ||
if #lista_elemek > 0 then | if #lista_elemek > 0 then | ||
return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin: 0;">' .. table.concat(lista_elemek) .. "</ul>" | return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin-top: 0; margin-bottom: 0;">' .. | ||
table.concat(lista_elemek) .. | |||
"</ul>" | |||
else | |||
return "" | |||
end | end | ||
end | end | ||
| 51. sor: | 64. sor: | ||
local sorszam = 0 | local sorszam = 0 | ||
-- Itt is ustring.gmatch-ot használunk a biztonság kedvéért | |||
for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do | for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do | ||
local | local taxon = "" | ||
local | local szinonimak = "" | ||
if mw.ustring.match(sor, "^ß") then | if mw.ustring.match(sor, "^ß") then | ||
local nemzettseg, tipus = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)") | |||
local nemzettseg, | |||
if nemzettseg then | if nemzettseg then | ||
taxon = "'''" .. mw.text.trim(nemzettseg):gsub("¤+", "") .. "'''" | |||
szinonimak = | szinonimak = tipus | ||
end | end | ||
elseif mw.ustring.match(sor, "^Ł") then | elseif mw.ustring.match(sor, "^Ł") then | ||
local tiszta_sor = mw.ustring.gsub(sor, "^Ł%s*", "") | local tiszta_sor = mw.ustring.gsub(sor, "^Ł%s*", "") | ||
local t, sz = mw.ustring.match(tiszta_sor, "([^¤]+)¤¤¤(.*)") | local t, sz = mw.ustring.match(tiszta_sor, "([^¤]+)¤¤¤(.*)") | ||
if t then | if t then | ||
taxon = "''" .. mw.text.trim(t) .. "''" | |||
szinonimak = sz | szinonimak = sz | ||
end | end | ||
end | end | ||
if | if taxon ~= "" then | ||
sorszam = sorszam + 1 | sorszam = sorszam + 1 | ||
res = res .. "|-\n" | res = res .. "|-\n" | ||
res = res .. "| " .. sorszam .. "\n" | res = res .. "| " .. sorszam .. "\n" | ||
res = res .. '| style="white-space: nowrap;" | ' .. | res = res .. '| style="white-space: nowrap;" | ' .. taxon .. "\n" | ||
res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n" | res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n" | ||
end | end | ||
A lap 2026. január 7., 08:18-kori változata
A modult a Modul:CactaceaeTaxonok/doc lapon tudod dokumentálni
local p = {}
-- Segédfüggvény a szimbólumok és HTML lista kezeléséhez (Unicode-biztos)
local function formazSzinonimak(szoveg)
if not szoveg or szoveg == "" then return "" end
-- 1. Felesleges karakterek törlése (Unicode-biztosan)
local tiszta = mw.ustring.gsub(szoveg, "[đ÷]", "")
tiszta = mw.ustring.gsub(tiszta, "¤+", "")
-- 2. Kacsacsőrös jelek egyszerűsítése (maradnak az adott sorban)
tiszta = mw.ustring.gsub(tiszta, ">−", "−")
tiszta = mw.ustring.gsub(tiszta, ">≡", "≡")
tiszta = mw.ustring.gsub(tiszta, ">=", "=")
-- 3. Új listapont jelölők átalakítása (ideiglenes elválasztó: | )
-- Csak a duplázott jeleknél darabolunk
tiszta = mw.ustring.gsub(tiszta, "≡≡", "|≡")
tiszta = mw.ustring.gsub(tiszta, "==", "|=")
tiszta = mw.ustring.gsub(tiszta, "−−", "|−")
-- A sima kötőjeleket külön kezeljük, mert a Lua mintában a - speciális karakter
tiszta = mw.ustring.gsub(tiszta, "%-%-", "|−")
-- 4. HTML lista építése
local lista_elemek = {}
-- Darabolás az mw.text.gsplit-tel (ez biztonságosabb)
for resz in mw.text.gsplit(tiszta, "|", true) do
local tiszta_resz = mw.text.trim(resz)
if tiszta_resz ~= "" then
-- Botanikai nevek dőltetése a részen belül
local szavak = {}
for szo in mw.ustring.gmatch(tiszta_resz, "%S+") do
-- Ha a szó szimbólumot, vesszőt tartalmaz vagy technikai rövidítés, marad álló
if mw.ustring.find(szo, "[≡=−,]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then
table.insert(szavak, szo)
else
table.insert(szavak, "''" .. szo .. "''")
end
end
local kesz_elem = table.concat(szavak, " ")
table.insert(lista_elemek, "<li>" .. kesz_elem .. "</li>")
end
end
if #lista_elemek > 0 then
return '<ul style="margin-left: 1.1em; list-style-type: disc; padding: 0; margin-top: 0; margin-bottom: 0;">' ..
table.concat(lista_elemek) ..
"</ul>"
else
return ""
end
end
function p.tablazat(frame)
local status, adatModul = pcall(require, 'Modul:CactaceaeTaxonokData')
if not status then return "Hiba: A 'Modul:CactaceaeTaxonokData' nem található!" end
local nyers_adat = adatModul.getAdatok()
local res = '{| class="wikitable sortable datatable-hook stripe hover compact" data-page-length="50" style="width:100%; font-size:90%;"\n'
res = res .. "! # !! Taxonnév !! Típusfaj, szinonima\n"
local sorszam = 0
-- Itt is ustring.gmatch-ot használunk a biztonság kedvéért
for sor in mw.ustring.gmatch(nyers_adat, "[^\r\n]+") do
local taxon = ""
local szinonimak = ""
if mw.ustring.match(sor, "^ß") then
local nemzettseg, tipus = mw.ustring.match(sor, "^ß%s*([^:]+)::%s*(.+)")
if nemzettseg then
taxon = "'''" .. mw.text.trim(nemzettseg):gsub("¤+", "") .. "'''"
szinonimak = tipus
end
elseif mw.ustring.match(sor, "^Ł") then
local tiszta_sor = mw.ustring.gsub(sor, "^Ł%s*", "")
local t, sz = mw.ustring.match(tiszta_sor, "([^¤]+)¤¤¤(.*)")
if t then
taxon = "''" .. mw.text.trim(t) .. "''"
szinonimak = sz
end
end
if taxon ~= "" then
sorszam = sorszam + 1
res = res .. "|-\n"
res = res .. "| " .. sorszam .. "\n"
res = res .. '| style="white-space: nowrap;" | ' .. taxon .. "\n"
res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n"
end
end
res = res .. "|}"
return frame:preprocess(res)
end
return p