什么是xml:

众所周知,xml常用语数据存储和传输,文件后缀为 .xml;

它是可扩展标记语言(Extensible Markup Language,简称XML),是一种标记语言。

如何定义这些标记,既可以选择国际通用的标记语言如HTML,也可以使用像XML这样由相关人士自由决定的标记语言,这就是语言的可扩展性。XML设计用来传送及携带数据信息,不用来表现或展示数据,所以XML用途的焦点是它说明数据是什么,以及携带数据信息。而HTML语言则用来表现数据。可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。在电子计算机中,标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种的信息比如文章等。它可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 它非常适合万维网传输,提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。是Internet环境中跨平台的、依赖于内容的技术,也是当今处理分布式结构信息的有效工具。早在1998年,W3C就发布了XML1.0规范,使用它来简化Internet的文档信息传输。

 

DOM4J:

通过DOM4J API和标准DOM接口具有并行访问功能,DOM4J使用接口和抽象基本类方法。DOM4J大量使用了API中的Collections类,例如大名鼎鼎的hibernate也用DOM4J来读取XML配置文件。如果不考虑可移植性,那就采用DOM4J.

 

-------------------------------------------------

DOM解析用例:

--------------------------------------------------

public class DOMforEm {

public static ArrayList<Employee> showEM() throws ParserConfigurationException, IOException, Exception{

ArrayList<Employee> list = new ArrayList<Employee>();

//1.得到DOM解析器的工厂实例

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

//2从工厂中获得DOM解析器

DocumentBuilder db = dbf.newDocumentBuilder();

//3把XML倒挂为一颗DOM树

Document doc = db.parse("employee.xml");

//4拿到节点集合

NodeList emList =doc.getElementsByTagName("em");

//5.遍历DOM树 ,循环节点信息

for(int i=0;i<emList.getLength();i++){

Employee emClass = new Employee();

//6.强转子节点为元素

Element em =(Element)emList.item(i);

//7.取得元素的属性值

String attrValue = em.getAttribute("id");

emClass.setNo(Integer.parseInt(attrValue));

//8循环每一个元素的子节点

         NodeList em2List = em.getChildNodes();        

         for(int j=0;j<em2List.getLength();j++){            

        Node item = em2List.item(j);        

//子节点不用强转

int type = item.getNodeType();

if(type==1){

String content = item.getTextContent();

String name = item.getNodeName();

if(name != null && name.equals("emname")){

emClass.setName(content);

}else if(name!= null && name.equals("job")){

emClass.setJob(content);

}else {

                 emClass.setSalary(content);

}

}

}

list.add(emClass);

}

return list;

}

public static void main(String[] args) {

try {

ArrayList<Employee> list = showEM();

for (int i = 0; i < list.size(); i++) {

System.out.println(list.get(i));

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

--------------------------------------------------

DOM4J解析xml整理

 

xml解析异常1:

java.io.UTFDataFormatException: Invalid byte 2 of 2-byte UTF-8 sequence.

异常分析:

由于声明的Xml是UTF-8编码的,而转换的时候使用默认的编码是gbk的

===============================

xml解析异常2:

The processing instruction target matching "[xX][mM][lL]" is not allowed. activity_main.xml

异常分析:

XML头信息写在最前面,

<?xml version="1.0" encoding="UTF-8"?> 前面不能有空格

====================================

加载xml文件:

==================

加载String类型的报文:

Document document = DocumentHelper.parseText(xmlResult);====

===================================

加载xml文件:

Document doc = null;

/**

* DOM4J加载xml文件

*/

public void LoadXML(String path){        

SAXReader saxReader= new SAXReader();

try {

//read()的入参可以是File,InputStream,Reader,URL等多种方式....,用字节流加载防止中文乱码,很重要

doc = saxReader.read(path);

} catch (Exception e) {

e.printStackTrace();

}

}

=============================================

/**

* 保存XML文件

* @param path

*/

public void saveXML(String path){

OutputFormat format = OutputFormat.createPrettyPrint();

format.setEncoding("UTF-8");

try {

XMLWriter writer = new XMLWriter(new FileWriter(path), format);

writer.write(doc);

writer.flush();

writer.close();

} catch (Exception e) {

e.printStackTrace();

}

}

=========================================

doc.asXML方法

将doc对象转化成xmlstring的格式,并可以将string打印出来。

拿到根节点对象

Element root =doc.getRootElement();

节点:

拿根节点对象: Element rootElem = document.getRootElement();

获取某节点的单个子节点:Element memberElem = root.element("节点名");

获取根节点下的所有的名为name子节点的集合并遍历:(遍历之前先判断有无子节点)

List nodes= root.elements("name");

for(Iterator it = nodes.iterator() ; it.hasNext() ; ){

Element elm = (Element) it.next();

.........

}

对某节点下所有的子节点进行遍历:

for(Iterator it = root.elementIterator() ; it.hasNext() ; ){

Element elm = (Element) it.next();

......

}

添加age子节点:

Element ageELm = newMenberElm.addElement("age");

删除子节点:

parentElm.remove(chaildElm);

Element.getParent().remove(Element);

==========================================

拿节点的内容1:

Element.getTextTrim()【忽略换行键】

Element.getText()【包含换行键】

若有子节点,则得到的String为空串"",遍历之前先判断否则空指针异常,例:

String text = root.getTextTrim();

if (!text.equals("")) {

System.out.println("根节点的内容是:"+text);

}else{

Iterator<Element> item = root.elementIterator();

int ii=1;//3遍历所有的元素

while(item.hasNext()){

..........

}

获取根节点下的name子节点的内容2:

String text = root.elementText("name");

设置/修改节点的内容:Element.setText("内容");

拿节点的名字 :Element.getName()

修改节点的名字 :Element.setName()================================================

属性:

获取某节点下的某属性(对象):

Atrribute attribute = root.attribute("size");

继而获取属性对象的值:

String text = attribute .getText();

也可以从节点对象取属性对象的值2:

Element.attributeValue("size");

 

遍历某节点的所有属性:

for(Iterator it = root.attributeIterator() ; it.hasNext() ; ){

Atrribute attribute = it.next();

String text = attribute .getText();

........

}

删除某属性:

Atrribute attribute = root.attribute("size");

root.remove(attribute);

//root.remove(root.attribute("size"));

 

添加节点属性 Element.addAttribute("language", "java");如果重复添加则覆盖,可当做修改操作

修改节点的值:Element.setText("值");

===============================================

 

 

 

XML—代码—DOM4J解析的更多相关文章

  1. xml之dom4j解析

    * 使用dom4j解析xml 实例在java520里面 TextDom4j * dom4j,是一个组织,针对xml解析,提供解析器dom4j * dom4j不是javase的一部分,想要使用第一步需要 ...

  2. xml的Dom4j解析规则

    一,xml的样本 <?xml version="1.0" encoding="utf-8"?> <contactList> <co ...

  3. java基础 xml 使用dom4j解析 xml文件 servlet根据pattern 找到class

    package com.swift.kaoshi; import java.io.File; import java.util.List; import java.util.Scanner; impo ...

  4. [工作代码]dom4j解析实例

    工作中,我需要和另一个公司(A公司)共同开发一个模块,我写一个servlet接口,A公司携带xml格式的报文来访问.我采用流的形式读取,在处理后以流的形式写入,在返回(相应)给A公司. demo: p ...

  5. XML(四)dom4j解析XML

    使用dom4j须要导入jar包 jar包下载地址:http://pan.baidu.com/s/1o65jWRw 将dom4j-1.6.1.jar包导入Eclipse book2.xml <?x ...

  6. Dom4j解析xml

    public class Dom4jTest { // Dom4j解析xml // 因为所有的方法都需要Dom树 static Document document = null; static Ele ...

  7. 【java项目实战】dom4j解析xml文件,连接Oracle数据库

    简单介绍 dom4j是由dom4j.org出品的一个开源XML解析包.这句话太官方.我们还是看一下官方给出的解释.例如以下图: dom4j是一个易于使用的.开源的,用于解析XML,XPath和XSLT ...

  8. xml(3)--dom4j实现crud操作

    1.XML解析技术概述 (1)XML解析方式分为两种:dom和sax     dom:(Document Object Model, 即文档对象模型) 是 W3C 组织推荐的处理 XML 的一种标准方 ...

  9. java中采用dom4j解析xml文件

    一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ...

随机推荐

  1. android开发,权限获取

    转:http://blog.csdn.net/yawinstake/article/details/6748897 访问登记属性 android.permission.ACCESS_CHECKIN_P ...

  2. 23种设计模式之抽象工厂(Abstract Factory)

    抽象工厂模式又称为Kit模式,属于对象创建型模式.抽象工厂模式是所有形式的工厂模式中最为抽象和最具一般性的一种形态,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类.在抽象工厂模 ...

  3. Android服务开发——WebService

    我在学习Android开发过程中遇到的第一个疑问就是Android客户端是怎么跟服务器数据库进行交互的呢?这个问题是我当初初次接触Android时所困扰我的一个很大的问题,直到几年前的一天,我突然想到 ...

  4. beetl的内置函数 (如strutil 工具类)

    转自:http://ibeetl.com/guide/ 2.19. 函数调用 Beetl内置函数请参考附录,以下列出了常用的函数 date 返回一个java.util.Date类型的变量,如 date ...

  5. http模拟登陆及发请求

    首先声明下,如果服务端写入的cookie属性是HttpOnly的,程序是不能自动获取cookie的,需要人工登陆网站获取cookie再把cookie写死,如下图所示: http测试工具:http:// ...

  6. hdu 2444 The Accomodation of Students 【二分图匹配】

    There are a group of students. Some of them may know each other, while others don't. For example, A ...

  7. strut2的标签

         DIY部落 新闻中心 交流论坛 千寻搜索   点击浏览该栏目下的更多电子书  收藏本站   struts2标签详解 文章整理: www.diybl.com 文章来源: 网络 去论坛 建我的b ...

  8. 查找算法:二分法查找及其python实现案例

    承接上一篇:查找:顺序查找与二分法查找,将二分法更多详细的python实现解题写下笔记. 简单方法 ''' 二分法查找在列表中的用户输入值,返回index 三种情况跳出循环体: LR相邻 LR位置重合 ...

  9. element 表格元素 超链接

    1.在循环体中的事件绑定 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  10. three levels of abstraction

    DATABASESYSTEM CONCEPTS SIXTH EDITION Abraham Silberschatz Yale University Henry F. KorthLehigh Univ ...