Lua:
פיענוח HTML
איך לעשות זאת:
ל-Lua אין ספרייה מובנית לפענוח HTML, אך ניתן להשתמש בספריות של צד שלישי כמו LuaHTML
או להיעזר בקשרים ל-libxml2
דרך LuaXML
. גישה פופולרית היא להשתמש בספריית lua-gumbo
לפענוח HTML, שמספקת יכולת פענוח תקנית וישירה ל-HTML5.
התקנת lua-gumbo:
ראשית, וודאו ש-lua-gumbo
מותקן. בדרך כלל תוכלו להתקין אותו באמצעות luarocks:
luarocks install lua-gumbo
פענוח בסיסי עם lua-gumbo:
הנה איך אפשר לפענח קטע HTML פשוט ולחלץ ממנו נתונים באמצעות lua-gumbo
:
local gumbo = require "gumbo"
local document = gumbo.parse[[<html><body><p>שלום, עולם!</p></body></html>]]
local p = document:getElementsByTagName("p")[1]
print(p.textContent) -- Output: שלום, עולם!
דוגמה מתקדמת - חילוץ קישורים:
לחילוץ מאפייני href
מכל תגיות העוגן (<a>
elements) במסמך HTML:
local gumbo = require "gumbo"
local document = gumbo.parse([[
<html>
<head><title>דף לדוגמה</title></head>
<body>
<a href="http://example.com/1">קישור 1</a>
<a href="http://example.com/2">קישור 2</a>
<a href="http://example.com/3">קישור 3</a>
</body>
</html>
]])
for _, element in ipairs(document.links) do
if element.getAttribute then -- לוודא שזה אלמנט ויש לו מאפיינים
local href = element:getAttribute("href")
if href then print(href) end
end
end
-- פלט לדוגמה:
-- http://example.com/1
-- http://example.com/2
-- http://example.com/3
קטע הקוד הזה עובר על כל הקישורים במסמך ומדפיס את מאפייני ה-href
שלהם. היכולת של ספריית ה-lua-gumbo
לפענח ולהבין את מבנה מסמך HTML מפשטת את התהליך של חילוץ יסודות ספציפיים לפי התגיות או המאפיינים שלהם.