„Modul:CactaceaeTaxonSzinonimák” változatai közötti eltérés
Megjelenés
Nincs szerkesztési összefoglaló |
Nincs szerkesztési összefoglaló |
||
| 1. sor: | 1. sor: | ||
local p = {} | local p = {} | ||
-- | -- Szigorú tisztítás az összehasonlításhoz és megjelenítéshez | ||
local function | local function cleanName(s) | ||
if not s then return "" end | if not s or s == "" then return "" end | ||
-- | -- Eltávolítjuk a sallangokat: számok, jelek, kettőskereszt, @, kettőspontok | ||
local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-−]+", "") | local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-−%:]+", "") | ||
return mw.text.trim(cleaned | return mw.text.trim(cleaned) | ||
end | end | ||
| 14. sor: | 14. sor: | ||
keresettTaxon = mw.text.trim(keresettTaxon) | keresettTaxon = mw.text.trim(keresettTaxon) | ||
local keresettAlacsony = keresettTaxon:lower() | local keresettAlacsony = cleanName(keresettTaxon):lower() | ||
local dataModul = require("Modul:CactaceaeTaxonokData") | local dataModul = require("Modul:CactaceaeTaxonokData") | ||
| 24. sor: | 24. sor: | ||
local talaltSor = nil | local talaltSor = nil | ||
-- | -- 1. KERESÉS ÉS ELŐTISZTÍTÁS | ||
for sor in nyersAdat:gmatch("[^\r\n]+") do | for sor in nyersAdat:gmatch("[^\r\n]+") do | ||
if mw.ustring.find( | -- AZONNALI TISZTÍTÁS: Kivágjuk a ":: Type: ..." részt, ha létezik | ||
local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1") | |||
local darabok = mw.text.split( | |||
-- Gyors előszűrés a tiszta soron | |||
if mw.ustring.find(tisztaSor:lower(), keresettAlacsony, 1, true) then | |||
local darabok = mw.text.split(tisztaSor, "#") | |||
for _, darab in ipairs(darabok) do | for _, darab in ipairs(darabok) do | ||
if | if cleanName(darab):lower() == keresettAlacsony then | ||
talaltSor = | talaltSor = tisztaSor | ||
break | break | ||
end | end | ||
| 43. sor: | 46. sor: | ||
end | end | ||
-- FELDOLGOZÁS ( | -- 2. FELDOLGOZÁS (már a Type-mentes soron) | ||
local | local elsoNevMatch = mw.ustring.match(talaltSor, "^%d+ ([^#≡=%-−]+)") | ||
local ervenyesNevFinal = cleanName(elsoNevMatch or "Ismeretlen taxon") | |||
local eredmeny = "== A ''" .. ervenyesNevFinal .. "'' szinonimái ==\n\n" | local eredmeny = "== A ''" .. ervenyesNevFinal .. "'' szinonimái ==\n\n" | ||
local lista = {} | local lista = {} | ||
local szinonimaDarabok = mw.text.split(talaltSor, "#") | local szinonimaDarabok = mw.text.split(talaltSor, "#") | ||
| 67. sor: | 60. sor: | ||
if jel and szint then | if jel and szint then | ||
local tisztaNev = cleanName(darab) | |||
local tisztaNev = | |||
local szam = tonumber(szint) | local szam = tonumber(szint) | ||
local aktJel = (jel == "≡") and homoHTML or ((jel == "-" or jel == "−") and hibaHTML or jel) | local aktJel = (jel == "≡") and homoHTML or ((jel == "-" or jel == "−") and hibaHTML or jel) | ||
| 86. sor: | 76. sor: | ||
end | end | ||
end | end | ||
-- 3. ÖSSZEÁLLÍTÁS | |||
if #lista == 0 then return eredmeny .. "* Nincsenek szinonimák." end | |||
for _, csoport in ipairs(lista) do | for _, csoport in ipairs(lista) do | ||
A lap 2026. január 11., 13:23-kori változata
A modult a Modul:CactaceaeTaxonSzinonimák/doc lapon tudod dokumentálni
local p = {}
-- Szigorú tisztítás az összehasonlításhoz és megjelenítéshez
local function cleanName(s)
if not s or s == "" then return "" end
-- Eltávolítjuk a sallangokat: számok, jelek, kettőskereszt, @, kettőspontok
local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-−%:]+", "")
return mw.text.trim(cleaned)
end
function p.keres(frame)
local keresettTaxon = frame.args[1] or frame:getParent().args[1]
if not keresettTaxon or keresettTaxon == "" then return "Nincs megadva taxon!" end
keresettTaxon = mw.text.trim(keresettTaxon)
local keresettAlacsony = cleanName(keresettTaxon):lower()
local dataModul = require("Modul:CactaceaeTaxonokData")
local nyersAdat = dataModul.getAdatok()
local homoHTML = "≡"
local hibaHTML = "−"
local talaltSor = nil
-- 1. KERESÉS ÉS ELŐTISZTÍTÁS
for sor in nyersAdat:gmatch("[^\r\n]+") do
-- AZONNALI TISZTÍTÁS: Kivágjuk a ":: Type: ..." részt, ha létezik
local tisztaSor = mw.ustring.gsub(sor, "%s*::%s*Type:.-(%d#)", " %1")
-- Gyors előszűrés a tiszta soron
if mw.ustring.find(tisztaSor:lower(), keresettAlacsony, 1, true) then
local darabok = mw.text.split(tisztaSor, "#")
for _, darab in ipairs(darabok) do
if cleanName(darab):lower() == keresettAlacsony then
talaltSor = tisztaSor
break
end
end
end
if talaltSor then break end
end
if not talaltSor then
return "A megadott taxon (''" .. keresettTaxon .. "'') nem található az adatbázisban."
end
-- 2. FELDOLGOZÁS (már a Type-mentes soron)
local elsoNevMatch = mw.ustring.match(talaltSor, "^%d+ ([^#≡=%-−]+)")
local ervenyesNevFinal = cleanName(elsoNevMatch or "Ismeretlen taxon")
local eredmeny = "== A ''" .. ervenyesNevFinal .. "'' szinonimái ==\n\n"
local lista = {}
local szinonimaDarabok = mw.text.split(talaltSor, "#")
for _, darab in ipairs(szinonimaDarabok) do
local jel = mw.ustring.match(darab, "([≡=%-−])")
local szint = mw.ustring.match(darab, "(%d+)$")
if jel and szint then
local tisztaNev = cleanName(darab)
local szam = tonumber(szint)
local aktJel = (jel == "≡") and homoHTML or ((jel == "-" or jel == "−") and hibaHTML or jel)
if tisztaNev ~= "" then
if szam == 4 and #lista > 0 then
table.insert(lista[#lista].nevek, {jel = aktJel, nev = tisztaNev})
else
table.insert(lista, {
elsoJel = aktJel,
nevek = {{jel = "", nev = tisztaNev}}
})
end
end
end
end
-- 3. ÖSSZEÁLLÍTÁS
if #lista == 0 then return eredmeny .. "* Nincsenek szinonimák." end
for _, csoport in ipairs(lista) do
local sorElemei = {}
for i, adat in ipairs(csoport.nevek) do
local elem = "''" .. adat.nev .. "''"
if i > 1 then elem = adat.jel .. " " .. elem end
table.insert(sorElemei, elem)
end
eredmeny = eredmeny .. "* " .. csoport.elsoJel .. " " .. table.concat(sorElemei, ", ") .. "\n"
end
return eredmeny
end
return p