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

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免费学习笔记(深入)”;

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文件的代码示例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1429026.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 02:09:13
下一篇 2025年12月17日 02:09:27

相关推荐

发表回复

登录后才能评论
关注微信