用Java解析XML文件的代码示例

互联网 17-4-27
用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API (Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object Module)称为DOM。

Sun公司提供了Java API for XML Parsing(JAXP)接口来使用SAX和DOM,通过JAXP,我们可以使用任何与JAXP兼容的XML解析器。 JAXP接口包含了三个包:

org.w3c.dom W3C推荐的用于XML标准规划文档对象模型的接口。

org.xml.sax用于对XML进行语法分析的事件驱动的XML简单API(SAX)

javax.xml.parsers解析器工厂工具,程序员获得并配置特殊的特殊语法分析器。

java XML parser

import java.io.FileInputStream;   import java.io.FileNotFoundException;   import java.io.IOException;   import java.io.InputStream;   import javax.xml.parsers.DocumentBuilder;   import javax.xml.parsers.DocumentBuilderFactory;   import javax.xml.parsers.ParserConfigurationException;   import org.w3c.dom.Document;   import org.w3c.dom.Element;   import org.w3c.dom.Node;   import org.w3c.dom.NodeList;   import org.xml.sax.SAXException;      public class DomParse {       public DomParse(){              DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();              try {               DocumentBuilder dombuilder=domfac.newDocumentBuilder();               InputStream is=new FileInputStream("WebRoot/WEB-INF/hell.xml");               Document doc=dombuilder.parse(is);               Element root=doc.getDocumentElement();               NodeList books=root.getChildNodes();                  if(books!=null){                   for(int i=0;i<books.getLength();i++){                       Node book=books.item(i);                       if(book.getNodeType()==Node.ELEMENT_NODE){                           String email=book.getAttributes().getNamedItem("email").getNodeValue();                           System.out.println(email);                           for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()){                               if(node.getNodeType()==Node.ELEMENT_NODE){                                   if(node.getNodeName().equals("name")){                                       String name=node.getNodeValue();                                       String name1=node.getFirstChild().getNodeValue();                                       System.out.println(name);                                       System.out.println(name1);                                   }                                      if(node.getNodeName().equals("price")){                                       String price=node.getFirstChild().getNodeValue();                                       System.out.println(price);                                   }                               }                           }                       }                   }               }           } catch (ParserConfigurationException e) {               e.printStackTrace();          } catch (FileNotFoundException e) {                e.printStackTrace();           } catch (SAXException e) {               e.printStackTrace();           } catch (IOException e) {               e.printStackTrace();           }       }          public static void main(String[] args)        {           new DomParse();       }       }

以上就是用Java解析XML文件的代码示例的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: Java,XML
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:dom4j解析xml文件代码示例

相关资讯