Egy elem keresése adott XML dokumentumban

Ebben a fejezetben megnézzük, hogyan lehet egy XML dokumentumban megkeresni egy elemet az org.apache.xerces.parsers.DOMParser csomag által definiált DOM API-k segítésével. Ne felejtsd el, hogy a classpath-nak tartalmaznia kell a xercesImpl.jar és a xml-apis.jar fájlokat a program futtatásához. Ezek letölthetőek a Xerces projekt oldaláról.

A program leírása:

A program bekéri az XML fájl nevét és ellenőrzi az elérhetőségét. Ha a fájl létezik elemzi a parse() metódus használatával. Ez a metódus a DOMParser segítségével elemzi az XML dokumentumot. A DOMParser az org.apache.xerces.parsers.DOMParser csomagban van definiálva, nagyon jól használható DOMParser objektum létrehozására. A program bekéri a keresendő XML elem nevét. A getLength() metódussal megszámolja a megadott elem előfordulását, ha az érték 0, akkor üzenetet jelenít meg a képernyőn, egyébként a darabszámot írja ki.

A minta XML fájl, Employee-Detail.xml:

<?xml version = "1.0" ?>
<Employee-Detail>

    <Employee>
        <Emp_Id>E-001</Emp_Id>
        <Emp_Name>Vinod</Emp_Name>
        <Emp_E-mail>Vinod1@yahoo.com</Emp_E-mail>
    </Employee>

    <Employee>
        <Emp_Id>E-002</Emp_Id>
        <Emp_Name>Amit</Emp_Name>
        <Emp_E-mail>Amit2@yahoo.com</Emp_E-mail>
    </Employee>

    <Employee>
        <Emp_Id>E-003</Emp_Id>
        <Emp_Name>Deepak</Emp_Name>
        <Emp_E-mail>Deepak3@yahoo.com</Emp_E-mail>
    </Employee>

</Employee-Detail>

A program, SearchElement.java:

import org.w3c.dom.*;
import org.apache.xerces.parsers.DOMParser;
import java.io.*;

public class SearchElement {

    public static void main(String[] args) {

        try {

            BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
            System.out.print("Enter file name: ");
            String str = bf.readLine();
            File file = new File(str);

            if (file.exists()) {

                DOMParser parser = new DOMParser();
                parser.parse(str);

                Document doc = parser.getDocument();
                System.out.print("Enter element that have to count: ");
                String ele = bf.readLine();
                NodeList list = doc.getElementsByTagName(ele);

                if(list.getLength() == 0) {

                    System.out.println("Element doesn't exist in the " + str + " Document.");
                }

                else {

                    System.out.println("Element occurrs " + list.getLength() + " times in the " + str);
                }
            }

            else {

                System.out.println("File not found!");
            }
        }

        catch (Exception e) {

            e.getMessage();
        }
    }
}

A következő fejezetben elkészítjük az első XML fájlt.