Ugrás a tartalomhoz

„Modul:CactaceaeTaxonSzinonimák” változatai közötti eltérés

Innen: MKOE wiki
Nincs szerkesztési összefoglaló
Nincs szerkesztési összefoglaló
4. sor: 4. sor:
local function cleanName(s)
local function cleanName(s)
     if not s or s == "" then return "" end
     if not s or s == "" then return "" end
     local cleaned = mw.ustring.gsub(s, "[%d#@]+", "")
    -- Csak a nevet tartjuk meg, a speciális karaktereket eldobjuk
     local cleaned = mw.ustring.gsub(s, "[%d#@≡=%-]+", "")
     return mw.text.trim(cleaned)
     return mw.text.trim(cleaned)
end
end
24. sor: 25. sor:
             local ervenyesNev = cleanName(ervenyesNevNyers)
             local ervenyesNev = cleanName(ervenyesNevNyers)
              
              
             -- 2. Szinonimák feldolgozása karakterenként
             -- 2. Feldolgozás a számok alapján (3-as = új sor, 4-es = soron belül)
             local szinonimaResz = mw.ustring.match(sor, "#(.*)$") or ""
             local eredmeny = "== A ''" .. ervenyesNev .. "'' szinonimái ==\n\n"
              
              
            -- Kikeressük az összes szinonima blokkot: JEL + NÉV + SZÁM
            -- Példa: ≡ Lobivia thionantha 4#
             local lista = {}
             local lista = {}
            local aktualisNev = ""
             for jel, nev, szint in mw.ustring.gmatch(sor, "([≡=%-])%s*([^#]+)%s+(%d+)#") do
            local aktualisJel = ""
                 local tisztaNev = cleanName(nev)
 
                local szam = tonumber(szint)
             for cp in mw.ustring.gcodepoint(szinonimaResz) do
                 local c = mw.ustring.char(cp)
                  
                  
                 if c == "≡" or c == "=" or c == "-" then
                 if tisztaNev ~= "" then
                     if aktualisJel ~= "" then
                     if szam == 4 and #lista > 0 then
                        local tiszta = cleanName(aktualisNev)
                        -- Ha 4-es, akkor az utolsó listaelemhez fűzzük
                        if tiszta ~= "" then
                         table.insert(lista[#lista].nevek, tisztaNev)
                            -- LOGIKA: Ha a jel ≡, akkor hozzáfűzzük az előzőhöz (akár = volt az, akár ≡)
                            if c == "≡" and #lista > 0 then
                                -- Ez a név még az előző jelhez tartozik, de a következő név már ≡ lesz
                                table.insert(lista[#lista].nevek, tiszta)
                            elseif aktualisJel == "≡" and #lista > 0 then
                                table.insert(lista[#lista].nevek, tiszta)
                            else
                                table.insert(lista, {
                                    jel = (aktualisJel == "≡" and homoHTML or aktualisJel),
                                    nevek = {tiszta}
                                })
                            end
                        end
                    end
                    aktualisJel = c
                    aktualisNev = ""
                else
                    aktualisNev = aktualisNev .. c
                end
            end
           
            -- Utolsó név mentése
            if aktualisJel ~= "" then
                local tiszta = cleanName(aktualisNev)
                if tiszta ~= "" then
                    if aktualisJel == "≡" and #lista > 0 then
                         table.insert(lista[#lista].nevek, tiszta)
                     else
                     else
                        -- Ha 3-as (vagy bármi más), új listapontot nyitunk
                         table.insert(lista, {
                         table.insert(lista, {
                             jel = (aktualisJel == "≡" and homoHTML or aktualisJel),
                             elsoJel = (jel == "≡" and homoHTML or jel),
                             nevek = {tiszta}
                             nevek = {tisztaNev}
                         })
                         })
                     end
                     end
                 end
                 end
             end
             end
           
            -- 3. Megjelenítés összeállítása
            if #lista == 0 then return eredmeny .. "* Nincs megadott szinonima." end


            -- 3. Megjelenítés
            local eredmeny = "== A ''" .. ervenyesNev .. "'' szinonimái ==\n\n"
           
             for _, elem in ipairs(lista) do
             for _, elem in ipairs(lista) do
                 local formalt = {}
                 local formalt = {}
82. sor: 57. sor:
                     table.insert(formalt, "''" .. n .. "''")
                     table.insert(formalt, "''" .. n .. "''")
                 end
                 end
                 -- A soron belüli neveket mindig ≡ jellel választjuk el
                 -- A soron belüli neveket mindig ≡ választja el
                 local nevekSora = table.concat(formalt, " " .. homoHTML .. " ")
                 local sorVeg = table.concat(formalt, " " .. homoHTML .. " ")
                 eredmeny = eredmeny .. "* " .. elem.jel .. " " .. nevekSora .. "\n"
                 eredmeny = eredmeny .. "* " .. elem.elsoJel .. " " .. sorVeg .. "\n"
             end
             end
              
              

A lap 2026. január 11., 12:46-kori változata

A modult a Modul:CactaceaeTaxonSzinonimák/doc lapon tudod dokumentálni

local p = {}

-- Tisztító függvény: számok, kettőskereszt, @ és felesleges szóközök nélkül
local function cleanName(s)
    if not s or s == "" then return "" end
    -- Csak a nevet tartjuk meg, a speciális karaktereket eldobjuk
    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
    
    local dataModul = require("Modul:CactaceaeTaxonokData")
    local nyersAdat = dataModul.getAdatok()
    
    local homoHTML = "≡"
    
    for sor in nyersAdat:gmatch("[^\r\n]+") do
        if mw.ustring.find(sor, keresettTaxon, 1, true) then
            
            -- 1. Érvényes név kinyerése
            local ervenyesNevNyers = mw.ustring.match(sor, "%d+ ([^#:=≡%-]+)")
            local ervenyesNev = cleanName(ervenyesNevNyers)
            
            -- 2. Feldolgozás a számok alapján (3-as = új sor, 4-es = soron belül)
            local eredmeny = "== A ''" .. ervenyesNev .. "'' szinonimái ==\n\n"
            
            -- Kikeressük az összes szinonima blokkot: JEL + NÉV + SZÁM
            -- Példa: ≡ Lobivia thionantha 4#
            local lista = {}
            for jel, nev, szint in mw.ustring.gmatch(sor, "([≡=%-])%s*([^#]+)%s+(%d+)#") do
                local tisztaNev = cleanName(nev)
                local szam = tonumber(szint)
                
                if tisztaNev ~= "" then
                    if szam == 4 and #lista > 0 then
                        -- Ha 4-es, akkor az utolsó listaelemhez fűzzük
                        table.insert(lista[#lista].nevek, tisztaNev)
                    else
                        -- Ha 3-as (vagy bármi más), új listapontot nyitunk
                        table.insert(lista, {
                            elsoJel = (jel == "≡" and homoHTML or jel),
                            nevek = {tisztaNev}
                        })
                    end
                end
            end
            
            -- 3. Megjelenítés összeállítása
            if #lista == 0 then return eredmeny .. "* Nincs megadott szinonima." end

            for _, elem in ipairs(lista) do
                local formalt = {}
                for _, n in ipairs(elem.nevek) do
                    table.insert(formalt, "''" .. n .. "''")
                end
                -- A soron belüli neveket mindig ≡ választja el
                local sorVeg = table.concat(formalt, " " .. homoHTML .. " ")
                eredmeny = eredmeny .. "* " .. elem.elsoJel .. " " .. sorVeg .. "\n"
            end
            
            return eredmeny
        end
    end
    
    return "A megadott taxon nem található."
end

return p