Extrahieren von Werten aus Elementattributen mit Jsoup und einer JavaScript-Stage

Fusion verfügt zwar über integrierte Jsoup-Selektorfunktionen, aber die Extraktionsmöglichkeiten sind begrenzt. Wenn Sie z.B. Attributwerte extrahieren möchten – insbesondere Attributwerte mit Sonderzeichen oder Leerzeichen in den Werten – müssen Sie eine benutzerdefinierte JavaScript-Stufe erstellen und die Extraktion dort implementieren.

Um dies zu erreichen:

1) Erstellen Sie eine benutzerdefinierte JavaScript-Stage und ordnen Sie sie direkt nach dem Apache Tika Parser an. Vergewissern Sie sich in der Apache Tika Parser-Stufe, dass sowohl „Geparsten Inhalt als XML oder HTML zurückgeben“ als auch „Original XML und HTML statt Tika XML Output zurückgeben“ markiert sind.

2) Fügen Sie Ihren Code hinzu. Für die Zwecke dieses Artikels habe ich das folgende Beispiel erstellt. Je nachdem, was Sie erreichen wollen, kann Ihr Code variieren:

function(doc) {  

    var Jsoup = org.jsoup.Jsoup;
    var content = doc.getFirstFieldValue("body");
    var jdoc = org.jsoup.nodes.Document;
    var div = org.jsoup.nodes.Element;
    var img = org.jsoup.nodes.Element;
    var iter = java.util.Iterator;
    var divs = org.jsoup.select.Elements;

    try {
        jdoc = Jsoup.parse(content);
        divs = jdoc.select("div");
        iter = divs.iterator();
        div = null; // initialize our value to null
        while (iter.hasNext()) {
            div = iter.next();
            if (div.attr("id").equals("featured-img")) {
                break;
            }
        }
        if (div != null) {
            img = div.child(0);
            logger.info("SRC: " + img.attr("src"));
            logger.info("ORIG FILE: " + img.attr("data-orig-file"));
            doc.addField("post_image", img.attr("src") + " | " + img.attr("data-orig-file"));
        }
        else {
            logger.warn("Div was null");
        }
    }
    catch (e) {
        logger.error(e);
    }
    return doc;
}

Schauen wir uns also an, was hier passiert:

1) Deklarieren Sie Java-Klassen und JavaScript-Variablen, die verwendet werden sollen. Beachten Sie, dass wir der Variable content den Inhalt zuweisen, der vom Apache Tika Parser gezogen wird

var Jsoup = org.jsoup.Jsoup;
var content = doc.getFirstFieldValue("body");
var doc = org.jsoup.nodes.Document;
var div = org.jsoup.nodes.Element;
var img = org.jsoup.nodes.Element;
var iter = java.util.Iterator;
var divs = org.jsoup.select.Elements;

2) Als nächstes ziehen wir die „div“-Elemente heraus und suchen nach einem mit der ID „featured-img“. Sobald wir es gefunden haben, brechen wir die Iteration ab und machen weiter. Hinweis: Ich verwende diese Art von Beispiel, um zu zeigen, wie man mit Elementattributwerten arbeitet, die Sonderzeichen oder Leerzeichen enthalten. Die Selektorsyntax von Jsoups funktioniert nicht wirklich gut mit diesen Arten von Schlüsselnamen.

 doc = Jsoup.parse(content); // parse the document
             divs = doc.select("div"); // select all the 'div' elements
             iter = divs.iterator(); // get an iterator for the list
            while (iter.hasNext()) { // iterate over the elements
                div = iter.next();
                if (div.attr("id").equals("featured-img")) { // if we find a match, assign and move on. 
                    break;
                }
            }

3) Schließlich legen wir die Werte im Dokument fest. Ich habe hier eine zusätzliche Protokollierung eingefügt, die letztendlich entfernt werden kann.

   if (div != null) {
                 img = div.child(0); // get the image element
                logger.info("SRC: " + img.attr("src"));
                logger.info("ORIG FILE: " + img.attr("data-orig-file"));
                doc.addField("post_image", img.attr("src") + " | " + img.attr("data-orig-file")); // set the values in the PipelineDocument
            } else {
                logger.warn("Div was null");
            }

Und das war’s dann auch schon! Viel Spaß beim Extrahieren!

You Might Also Like

4 bewährte KI-Suchlösungen für die Tarifverwaltung

Entdecken Sie, wie KI-Suchlösungen für das Tarifmanagement Einzelhändlern helfen, Margen und Kundenzufriedenheit...

Read More

KI-Agenten dominieren den Einkauf. Ist Ihre Website auf die KI-gestützte Suche vorbereitet?

Generative KI-Agenten wie ChatGPT definieren die Produktsuche neu. Erfahren Sie, wie Sie...

Read More

Vom Suchunternehmen zum praktischen KI-Pionier: Unsere Vision für 2025 und darüber hinaus

CEO Mike Sinoway gibt Einblicke in die Zukunft der KI und stellt...

Read More

Quick Links