„Modul:CactaceaeTaxonok” változatai közötti eltérés
Megjelenés
Nincs szerkesztési összefoglaló |
Nincs szerkesztési összefoglaló |
||
| 5. sor: | 5. sor: | ||
if not szoveg or szoveg == "" then return "" end | if not szoveg or szoveg == "" then return "" end | ||
-- 1. Felesleges technikai karakterek törlése | -- 1. Felesleges technikai karakterek törlése | ||
local tiszta = szoveg:gsub("[đ÷]", ""):gsub("¤+", "") | local tiszta = szoveg:gsub("[đ÷]", ""):gsub("¤+", "") | ||
-- 2. Átalakítások | -- 2. Átalakítások: | ||
-- ≡≡ | -- A ≡≡ marad egy sorban vesszővel | ||
-- == | -- A == és −− új sorba kerül igazi wiki felsorolásként | ||
tiszta = tiszta:gsub("≡≡", ", ≡") | tiszta = tiszta:gsub("≡≡", ", ≡") | ||
tiszta = tiszta:gsub("==", "\n* =") | |||
tiszta = tiszta:gsub("−−", "\n* −") | |||
tiszta = tiszta:gsub("%-%-", "\n* −") | |||
tiszta = tiszta:gsub(">≡", ", >≡") | |||
tiszta = tiszta:gsub(">−", ", >−") | |||
-- 3 | -- 3. Formázás szavanként (Dőltetés) | ||
local szavak = {} | local szavak = {} | ||
for szo in tiszta:gmatch("%S+") do | for szo in tiszta:gmatch("%S+") do | ||
-- | -- A speciális karaktereket és rövidítéseket nem dőltetjük | ||
if szo:match("[≡=>−,*]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then | if szo:match("[≡=>−,*]") or szo == "var." or szo == "subsp." or szo == "f." or szo == "Type:" then | ||
table.insert(szavak, szo) | table.insert(szavak, szo) | ||
else | else | ||
table.insert(szavak, "''" .. szo .. "''") | table.insert(szavak, "''" .. szo .. "''") | ||
end | end | ||
end | end | ||
local vegso_szoveg = table.concat(szavak, " ") | |||
-- Megtisztítjuk az elejét a felesleges vesszőtől | |||
vegso_szoveg = vegso_szoveg:gsub("^,%s*", "") | |||
return vegso_szoveg | |||
end | end | ||
function p.tablazat(frame) | function p.tablazat(frame) | ||
local status, adatModul = pcall(require, 'Modul:CactaceaeTaxonokData') | local status, adatModul = pcall(require, 'Modul:CactaceaeTaxonokData') | ||
if not status then return "Hiba: A 'Modul:CactaceaeTaxonokData' nem található!" end | if not status then return "Hiba: A 'Modul:CactaceaeTaxonokData' nem található!" end | ||
| 45. sor: | 43. sor: | ||
local nyers_adat = adatModul.getAdatok() | local nyers_adat = adatModul.getAdatok() | ||
-- | -- Fontos: a táblázat marad a datatable-hook osztályú | ||
local res = '{| class="wikitable sortable datatable-hook stripe hover compact" data-page-length="50" style="width:100%; font-size:90%;"\n' | 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" | res = res .. "! # !! Taxonnév !! Típusfaj, szinonima\n" | ||
| 55. sor: | 53. sor: | ||
if sor:match("^ß") then | if sor:match("^ß") then | ||
local nemzettseg, tipus = sor:match("^ß%s*([^:]+)::%s*(.+)") | local nemzettseg, tipus = sor:match("^ß%s*([^:]+)::%s*(.+)") | ||
if nemzettseg then | if nemzettseg then | ||
taxon = "'''" .. mw.text.trim(nemzettseg | taxon = "'''" .. mw.text.trim(nemzettseg) .. "'''" | ||
szinonimak = tipus | szinonimak = tipus | ||
end | end | ||
elseif sor:match("^Ł") then | elseif sor:match("^Ł") then | ||
local tiszta = sor:gsub("^Ł%s*", "") | local tiszta = sor:gsub("^Ł%s*", "") | ||
local t, sz = tiszta:match("([^¤]+)¤¤¤(.*)") | local t, sz = tiszta:match("([^¤]+)¤¤¤(.*)") | ||
| 74. sor: | 70. sor: | ||
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;" | ' .. taxon .. "\n" | res = res .. '| style="white-space: nowrap;" | ' .. taxon .. "\n" | ||
-- | -- A cella tartalmát egy új sorral kezdjük, hogy a '*' felsorolás működjön | ||
res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n" | res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n" | ||
end | end | ||
| 84. sor: | 78. sor: | ||
res = res .. "|}" | res = res .. "|}" | ||
return res | |||
-- Ezt a preprocess-t hozzáadjuk, hogy a generált '*' jeleket valódi listává alakítsa | |||
return frame:preprocess(res) | |||
end | end | ||
return p | return p | ||
A lap 2026. január 7., 07:36-kori változata
A modult a Modul:CactaceaeTaxonok/doc lapon tudod dokumentálni
local p = {}
-- Segédfüggvény a szimbólumok és formázás kezeléséhez
local function formazSzinonimak(szoveg)
if not szoveg or szoveg == "" then return "" end
-- 1. Felesleges technikai karakterek törlése
local tiszta = szoveg:gsub("[đ÷]", ""):gsub("¤+", "")
-- 2. Átalakítások:
-- A ≡≡ marad egy sorban vesszővel
-- A == és −− új sorba kerül igazi wiki felsorolásként
tiszta = tiszta:gsub("≡≡", ", ≡")
tiszta = tiszta:gsub("==", "\n* =")
tiszta = tiszta:gsub("−−", "\n* −")
tiszta = tiszta:gsub("%-%-", "\n* −")
tiszta = tiszta:gsub(">≡", ", >≡")
tiszta = tiszta:gsub(">−", ", >−")
-- 3. Formázás szavanként (Dőltetés)
local szavak = {}
for szo in tiszta:gmatch("%S+") do
-- A speciális karaktereket és rövidítéseket nem dőltetjük
if szo:match("[≡=>−,*]") 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 vegso_szoveg = table.concat(szavak, " ")
-- Megtisztítjuk az elejét a felesleges vesszőtől
vegso_szoveg = vegso_szoveg:gsub("^,%s*", "")
return vegso_szoveg
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()
-- Fontos: a táblázat marad a datatable-hook osztályú
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
for sor in nyers_adat:gmatch("[^\r\n]+") do
local taxon = ""
local szinonimak = ""
if sor:match("^ß") then
local nemzettseg, tipus = sor:match("^ß%s*([^:]+)::%s*(.+)")
if nemzettseg then
taxon = "'''" .. mw.text.trim(nemzettseg) .. "'''"
szinonimak = tipus
end
elseif sor:match("^Ł") then
local tiszta = sor:gsub("^Ł%s*", "")
local t, sz = tiszta:match("([^¤]+)¤¤¤(.*)")
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"
-- A cella tartalmát egy új sorral kezdjük, hogy a '*' felsorolás működjön
res = res .. "| " .. formazSzinonimak(szinonimak) .. "\n"
end
end
res = res .. "|}"
-- Ezt a preprocess-t hozzáadjuk, hogy a generált '*' jeleket valódi listává alakítsa
return frame:preprocess(res)
end
return p