xml文件如下:
<?xml version="1.0" encoding="UTF-8"?> <articles> <article category="xml"> <title>xml概述</title> <author>janet</author> <email>janetvsfei@yahoo.com.cn</email> <date>20080801</date> </article> <article category="java"> <title>Java基本语法</title> <author>janet</author> <email>janetvsfei@yahoo.com.cn</email> <date>20080802</date> </article> </articles>
注意:xml文件的顶部<?xml version="1.0" encoding="UTF-8"?>这句话之前不能有任何空格,空行之类的,否则会出错。
1、用纯DOM来做。
用Element root=document.getDocumentElement()拿到根后,然后不停的遍历即可。
DOM的特点是将XML映射成一个Document,是一次性将所有XML全部载入到内存中。
例子如下:
package testXmlParse.dom; import java.io.File; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; public class TestXml_DOM { public static void main(String[] args) { File file=new File("D:\\temp\\Bosch\\articles.xml"); DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance(); try { DocumentBuilder db= dbf.newDocumentBuilder(); Document document=db.parse(file);//开始解析文件 //下面拿到根 Element root=document.getDocumentElement(); System.out.println(root.getNodeName()); //开始遍历根下面的子结点 NodeList nodeList=root.getChildNodes(); for(int i=0;i<nodeList.getLength();i++){ Node node=nodeList.item(i); if("article".equals(node.getNodeName())){ //打印书的分类名称 System.out.println("\r\n找到一本新书,书的分类是:"+node.getAttributes().getNamedItem("category").getNodeValue()+"."); //取得article下面的所有子结点 NodeList childNodeList=node.getChildNodes(); //遍历article for(int j=0;j<childNodeList.getLength();j++){ //拿到article下面的每一个item Node childNode=childNodeList.item(j); if("title".equals(childNode.getNodeName())){ System.out.println("title:"+childNode.getTextContent()); }else if("author".equals(childNode.getNodeName())){ System.out.println("author:"+childNode.getTextContent()); }else if("email".equals(childNode.getNodeName())){ System.out.println("email:"+childNode.getTextContent()); }else if("date".equals(childNode.getNodeName())){ System.out.println("date:"+childNode.getTextContent()); } } } } } catch (Exception e) { e.printStackTrace(); } } }
2、用SAX来做:
比纯DOM方便,快的多,是只把需要的载入内存中,不像DOM那样全部载入内存。
缺点是只能以File为载体,单纯的String好像不能解析,研究中……
package testXmlParse.sax; import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class XmlParse { public static void main(String[] args) { File xmlFile=new File("d:/temp/Bosch/onhand.xml"); SAXParserFactory factory=SAXParserFactory.newInstance(); try { SAXParser parser=factory.newSAXParser(); parser.parse(xmlFile, new MySaxHandler()); } catch (Exception e) { e.printStackTrace(); } } }
package testXmlParse.sax; import java.text.DateFormat; import java.text.SimpleDateFormat; import org.xml.sax.Attributes; import org.xml.sax.SAXException; import org.xml.sax.helpers.DefaultHandler; public class MySaxHandler extends DefaultHandler { static DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); private String content; @Override public void characters(char[] ch, int start, int length) throws SAXException { content = new String(ch, start, length); } @Override public void endElement(String uri, String localName, String name) throws SAXException { if ("title".equals(name)) { System.out.println("标题:" + content); } else if ("author".equals(name)) { System.out.println("作者:" + content); } else if ("email".equals(name)) { System.out.println("电子邮件:" + content); } else if ("body".equals(name)) { System.out.println("内容:" + content); } else if ("date".equals(name)) { System.out.println("发表日期:" + content); } } @Override public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException { if ("article".equals(name)) { System.out.println("\r\n找到一篇文章,所属分类:" + attributes.getValue("category")+". "); } } }
3、DOM4J
package testXmlParse.dom4j; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.apache.log4j.Logger; import org.dom4j.Element; /** * @autor germmy * @date 2012-12-11 * @version */ @SuppressWarnings("unchecked") public class XmlUtil { protected static Logger logger = Logger.getLogger(Dom4jParser.class); public static final String[]NODENAMES={"title","author","email","date"}; /** * 采用指定的编码读取XML * * @param fileName * @return */ public static String readFile_encoding(String fileName) { String encoding = "UTF-8"; // 字符编码 File file = new File(fileName); BufferedReader reader = null; StringBuffer sb = new StringBuffer(""); try { // reader = new BufferedReader(new FileReader(file)); InputStreamReader read = new InputStreamReader(new FileInputStream( file), encoding); reader = new BufferedReader(read); String tempString = null; int line = 1; while ((tempString = reader.readLine()) != null) { sb.append(tempString); line++; } reader.close(); } catch (IOException e) { e.printStackTrace(); } finally { if (reader != null) { try { reader.close(); } catch (IOException e1) { } } } return sb.toString(); } public static List getOrderInfoList(String xml){ List list=new ArrayList(); Map map=new HashMap(); try { List articles = Dom4jParser.getElements(xml,"article");// 所有的Item节点 if(articles!=null){ logger.debug("article.length["+articles.size()+"]"); for (int i = 0; i < articles.size(); i++) { map=new HashMap(); list.add(map); Element element = (Element) articles.get(i); for(int j=0;j<NODENAMES.length;j++){ Dom4jParser.parseText(map,element,NODENAMES[j]); } } } } catch (Exception e) { list=null; logger.error("",e); } return list; } public static void main(String[] args) { String xml=readFile_encoding("d:/temp/Bosch/articles.xml"); XmlUtil.getOrderInfoList(xml); //getOrders(ConfigUtil.testXml); } }
package testXmlParse.dom4j; import java.util.List; import java.util.Map; import org.apache.log4j.Logger; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.DocumentHelper; import org.dom4j.Element; /** * @autor germmy * @date 2012-12-11 * @version */ @SuppressWarnings("unchecked") public class Dom4jParser { protected static Logger logger = Logger.getLogger(Dom4jParser.class); public static Document getDom4JDocument(String xml){ Document doc = null; try { doc = DocumentHelper.parseText(xml); } catch (DocumentException e) { logger.error("",e); } return doc; } public static Element getRoot(String xml){ Document doc=getDom4JDocument(xml); if(doc!=null){ Element root = doc.getRootElement();// 指向根节点 return root; }else{ return null; } } public static List getElements(String xml,String nodeName){ Document doc=getDom4JDocument(xml); List elements=null; if(doc!=null){ Element root = doc.getRootElement();// 指向根节点 if(root!=null){ elements = root.elements(nodeName);// 所有的Item节点 } } if(elements==null){ logger.debug("can't find elements["+nodeName+"] in xml"); } return elements; } public static void parseText(Map map,Element element,String nodeName){ Element e=element.element(nodeName); if(e!=null){ System.out.println("nodeName:"+nodeName); System.out.println("value:"+e.getTextTrim()); map.put(nodeName, e.getTextTrim()); }else{ logger.debug("can't find Element["+nodeName+"] in xml"); } } }
4、SAXReader,以前写过,待整理。
refurl:http://developer.51cto.com/art/200903/117512.htm xml解析的4个方法
相关推荐
本篇文章将详细探讨一种比较通用的XML解析方法,适用于各种编程环境。 在处理XML文件时,我们通常会遇到两种主要的解析方式:DOM(Document Object Model)和SAX(Simple API for XML)。DOM将整个XML文档加载到...
本压缩包文件"安卓网站交互JSONxmlWebserviceUPnP相关-比较通用的xml解析方法.rar"主要关注XML解析方法,虽然未提及具体的所有内容,但我们可以根据标签和描述来探讨这些关键知识点。 首先,让我们深入了解一下JSON...
这个压缩包“比较通用的xml解析方法.zip”包含了一些与XML解析相关的资源,如库文件和源码示例,让我们逐一探讨。 1. **DOM4J.jar**: DOM4J 是一个灵活的 Java XML API,它提供了全面的功能,包括文档对象模型...
本资料包“安卓Android源码——比较通用的xml解析方法”将深入探讨在Android平台上解析XML的多种方法。 1. DOM解析器(Document Object Model) DOM解析器将整个XML文档加载到内存中,创建一个树形结构,便于遍历和...
本文将深入探讨三种主要的XML解析方法:DOM解析、SAX解析和DOM4J解析,并分析它们各自的特点和优势。 1. DOM解析(Document Object Model) DOM解析器将整个XML文档加载到内存中,构建一个树形结构,称为DOM树。...
7. **实际应用**:了解了基本的XML解析方法后,我们可以将其应用到实际项目中,比如读取配置文件、从网络获取XML数据、存储游戏数据等。 8. **源码分析**:教程中提供的源码是学习易语言XML解析的重要资源。通过...
本资料包“应用源码之比较通用的xml解析方法”专注于讲解如何在Android环境中解析XML文件,这对于理解和优化应用程序的性能至关重要。下面我们将深入探讨XML解析的几种方法及其优缺点。 1. DOM解析器(Document ...
Android提供了两种主要的XML解析方法:DOM(Document Object Model)解析和SAX(Simple API for XML)解析。 1. DOM解析: DOM解析器将整个XML文档加载到内存中,形成一个树形结构。开发者可以通过这个树形结构轻松...
本资料“比较通用的xml解析方法”探讨了在Android中解析XML的几种常见方法。 1. DOM解析器: DOM(Document Object Model)是XML文档的树形结构表示。它一次性加载整个XML文档到内存中,形成一个完整的树形结构,...
本教程将详细介绍四种常见的XML解析方法,以帮助你更好地理解和处理XML数据。 1. DOM解析器(Document Object Model) DOM解析器将整个XML文档加载到内存中,创建一个树形结构,允许开发者通过节点操作来访问和修改...
本文将深入探讨三种XML解析方法:JAXB(Java Architecture for XML Binding)、DOM4J以及DOM(Document Object Model)。 首先,JAXB是Java平台标准的一部分,它提供了一种将Java对象绑定到XML的机制,使得数据交换...
本项目"比较通用的xml解析方法.zip"提供了一个安卓应用的源码,主要关注XML在Android环境下的解析方法。下面我们将深入探讨XML解析在Android中的重要性以及几种常见的解析方式。 XML解析是Android开发中必不可少的...
本资源“安卓Android源码——比较通用的xml解析方法.zip”显然聚焦于探讨在Android平台上解析XML的不同方法。这里我们将深入探讨两种主要的XML解析技术:SAX(Simple API for XML)和DOM(Document Object Model),...
本示例着重于Android中的两种主要XML解析方法:DOM(Document Object Model)解析和SAX(Simple API for XML)解析。这两种方法各有优缺点,适用于不同的场景。 首先,DOM解析是最常见的方法之一。它将整个XML文档...
本资料"Android高级应用源码-比较通用的xml解析方法.zip"包含了关于XML解析的一些通用实现,旨在帮助开发者理解和掌握Android中处理XML的多种方法。以下是对这些知识点的详细解释: 1. DOM解析: Document Object ...