Find value of specific attribute in XML file in java

I just need to read the value of one attribute inside an XML file using java. The XML will look something like this:

<behavior name="Fred" version="2.0" ....>

      

and I just need to read the version. Can anyone point towards a resource that will show me how to do this?

+2


source to share


6 answers


You don't need a fancy library - plain old versions of JAXP DOM and XPath are pretty easy to read and write to do this. Whatever you do, don't use a regular expression.



import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathFactory;

import org.w3c.dom.Document;

public class GetVersion {
    public static void main(String[] args) throws Exception {
        XPath xpath = XPathFactory.newInstance().newXPath();
        Document doc = DocumentBuilderFactory.newInstance()
            .newDocumentBuilder().parse("file:////tmp/whatever.xml");
        String version = xpath.evaluate("//behavior/@version", doc);
        System.out.println(version);
    }
}

      

+3


source


Here alone .



import javax.xml.parsers.SAXParser;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.SAXException;
import org.xml.sax.Attributes;
import javax.xml.parsers.SAXParserFactory;

/**
 * Here is sample of reading attributes of a given XML element.
 */

public class SampleOfReadingAttributes {
    /**
     * Application entry point
     * @param args command-line arguments
     */
    public static void main(String[] args) {
        try {
            // creates and returns new instance of SAX-implementation:
            SAXParserFactory factory = SAXParserFactory.newInstance();

            // create SAX-parser...
            SAXParser parser = factory.newSAXParser();
            // .. define our handler:
            SaxHandler handler = new SaxHandler();

            // and parse:
            parser.parse("sample.xml", handler);

        } catch (Exception ex) {
            ex.printStackTrace(System.out);
        }
    }

    /**
     * Our own implementation of SAX handler reading
     * a purchase-order data.
     */
    private static final class SaxHandler extends DefaultHandler {

        // we enter to element 'qName':
        public void startElement(String uri, String localName,
                String qName, Attributes attrs) throws SAXException {

            if (qName.equals("behavior")) {
                // get version
                String version = attrs.getValue("version");


                System.out.println("Version is " + version );

            }
        }
    }
}

      

+1


source


As mentioned, you can use SAXParser.

Digester mentioned using regular expressions, which I won't recommend as it would lead to code that is difficult to maintain: what if you add a different version attribute to a different tag or a different behavior tag? You can handle it, but it won't be pretty.

You can also use XPath , which is the xml query language. This is what I would recommend.

+1


source


JAXB for brevity:

  private static String readVersion(File file) {
    @XmlRootElement class Behavior {
      @XmlAttribute String version;
    }
    return JAXB.unmarshal(file, Behavior.class).version;
  }

      

StAX for efficiency:

  private static String readVersionEfficient(File file)
      throws XMLStreamException, IOException {
    XMLInputFactory inFactory = XMLInputFactory.newInstance();
    XMLStreamReader xmlReader = inFactory
        .createXMLStreamReader(new StreamSource(file));
    try {
      while (xmlReader.hasNext()) {
        if (xmlReader.next() == XMLStreamConstants.START_ELEMENT) {
          if (xmlReader.getLocalName().equals("behavior")) {
            return xmlReader.getAttributeValue(null, "version");
          } else {
            throw new IOException("Invalid file");
          }
        }
      }
      throw new IOException("Invalid file");
    } finally {
      xmlReader.close();
    }
  }

      

+1


source


If you only need to read the version, you can use a regular expression. But actually, I think you need apache digester

0


source


0


source







All Articles