1.DMO解析

package cn.itcast.xml.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 Demo1 {
public static void main(String[] args) throws Exception {
//1 创建JAXPDOM 解析器工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//2 通过工厂获得解析器
DocumentBuilder builder= factory.newDocumentBuilder();
//3 使用解析器解析文档得到Domcument对象
Document doc = builder.parse(new File("src/student.xml"));
//...........
//拿到所有的学生并打印学生信息
//1 获得所有student元素对象
NodeList students = doc.getElementsByTagName("student");
//2 遍历这些对象.取得number属性
for(int i = 0 ; i < students.getLength() ; i++ ){
/*if( students.item(i) instanceof Element){//判断是不是ELement对象
Element student = (Element)students.item(i);
}*/
if(students.item(i).getNodeType() == Node.ELEMENT_NODE){
Element student = (Element)students.item(i);
String number = student.getAttribute("number");
System.out.println("当前学生的学号是"+number);
//3 取得子元素.遍历子元素
NodeList list = student.getChildNodes();
for(int x = 0 ; x < list.getLength() ; x++){
if(list.item(x).getNodeType() == Node.ELEMENT_NODE){
// info可能是 name age sex
Element info = (Element)list.item(x);
// Node nodeName ==> 标签名
if(info.getNodeName().equals("name")){
System.out.println("当前学生的姓名是"+info.getTextContent());
}else if(info.getNodeName().equals("age")){
System.out.println("当前学生的年龄是是"+info.getTextContent());
}else if(info.getNodeName().equals("sex")){
System.out.println("当前学生的性别是"+info.getTextContent());
}
}
} } }
//4取得对应 名称 年龄 性别
}
}

2.SAX解析

1.重写处理函数

package cn.itcast.xml.sax;

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; public class MyHandler extends DefaultHandler { @Override
public void startDocument() throws SAXException {
super.startDocument();
System.out.println("文档开始解析!");
} @Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
System.out.println("当前遍历的标签是"+qName);
String number = attributes.getValue("number"); if(!"".equals(number) && number!=null){
System.out.println("学生的学号是:"+number);
}
} @Override
public void characters(char[] ch, int start, int length)
throws SAXException {
String str =new String(ch,start,length);
//去掉空白文本
str = str.trim(); if(str.length() != 0){
System.out.println("当前解析的文本是:"+str);
} }
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
super.endElement(uri, localName, qName);
System.out.println(qName+"元素解析结束");
} @Override
public void endDocument() throws SAXException {
super.endDocument();
System.out.println("文档结束解析!");
}
}

2.使用它

package cn.itcast.xml.sax;

import java.io.File;

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; public class Demo1 {
public static void main(String[] args) throws Exception {
//1 创建sax 解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
//2 获得sax解析器
SAXParser saxParser =factory.newSAXParser();
//3 使用sax解析器解析xml文档.
saxParser.parse(new File("src/student.xml"), new MyHandler());
}
}

3.DEMO4J

1.读取 xml文档并打印文档内容

package cn.itcast.xml.dom4j;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader; public class Demo1 {
//hello 读取 xml文档并打印文档内容
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
System.out.println(document.asXML());
}
}

2.取出所有学生的信息

package cn.itcast.xml.dom4j;

import java.util.Iterator;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; public class Demo2 {
//取出所有学生的信息
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
//通过文档对象获得 根节点
Element root = document.getRootElement();
//遍历根节点下 ,名字为student的子元素节点
for ( Iterator i = root.elementIterator( "student" ); i.hasNext(); ) {
Element student = (Element) i.next();
//获得学生的number属性
String number = student.attributeValue("number");
System.out.println("学生的学号是"+number);
//获得学生的子元素
for ( Iterator j = student.elementIterator(); j.hasNext(); ) {
//可能是name age sex
Element info = (Element) j.next();
//获得元素的元素名
if(info.getName().equals("name")){
System.out.println("学生的姓名是"+info.getText());
}else if(info.getName().equals("age")){
System.out.println("学生的年龄是"+info.getText());
}else if(info.getName().equals("sex")){
System.out.println("学生的性别是"+info.getText());
}
} } }
}

3.(增)增加一个学生.学号ITCAST_0003,名字 zhangsan 年龄30 性别male

package cn.itcast.xml.dom4j;

import java.io.FileWriter;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo3 {
//增加一个学生.学号ITCAST_0003,名字 zhangsan 年龄30 性别male
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
//通过文档对象获得 根节点
Element root = document.getRootElement(); //1.在根元素下添加学生元素
Element student = root.addElement("student");
//2.为学生元素添加number属性
student.addAttribute("number", "ITCAST_0003");
//3.为学生元素添加子元素name age sex
//4.为子元素添加标签体
student.addElement("name").addText("zhangsan");
student.addElement("age").addText("30");
student.addElement("sex").addText("male"); //将内存中的Document会写到文件中 // Pretty print the document to System.out
OutputFormat format = OutputFormat.createPrettyPrint();
//创建一个xml的写入器. 构造函数中传入 写入的文件的位置和 格式化器
XMLWriter writer = new XMLWriter( new FileWriter( "src/student_copy.xml" ), format );
writer.write( document );
writer.close(); /* //创建一个xml的写入器. 构造函数中传入 写入的文件的位置
XMLWriter writer = new XMLWriter( new FileWriter( "src/student_copy.xml" ) );
// 写入什么
writer.write( document );
//关闭并释放资源
writer.close();*/
}
}

4.(改)修改一个学生.学号ITCAST_0001的学生年龄改为18

package cn.itcast.xml.dom4j;

import java.io.FileWriter;
import java.util.List; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo4 {
// 修改一个学生.学号ITCAST_0001的学生年龄改为18
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
// 通过文档对象获得 根节点
Element root = document.getRootElement();
// 1.获取到学生元素对象集合
List<Element> list = root.elements();
// 2.遍历集合
for (int i = 0; i < list.size(); i++) {
Element student = list.get(i);
// 通过number属性找出要修改的student对象
if (student.attributeValue("number").equals("ITCAST_0001")) {
// 3.设置student元素对象age子元素的文本为18
student.element("age").setText("18");
}
} // 将内存中的Document会写到文件中 // Pretty print the document to System.out
OutputFormat format = OutputFormat.createPrettyPrint();
// 创建一个xml的写入器. 构造函数中传入 写入的文件的位置和 格式化器
XMLWriter writer = new XMLWriter(
new FileWriter("src/student_copy.xml"), format);
writer.write(document);
writer.close(); /*
* //创建一个xml的写入器. 构造函数中传入 写入的文件的位置 XMLWriter writer = new XMLWriter( new
* FileWriter( "src/student_copy.xml" ) ); // 写入什么 writer.write(
* document ); //关闭并释放资源 writer.close();
*/
}
}

5.(删)删除学号ITCAST_0001的学生

package cn.itcast.xml.dom4j;

import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter; import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo6 {
// 删除学号ITCAST_0001的学生
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
// 通过文档对象获得 根节点
Element root = document.getRootElement(); //1.获取要删除的学生元素(xpath)
String xpath = "//student[@number='ITCAST_0001']";
Element student = (Element) root.selectSingleNode(xpath);
//2.删除(找父节点删)
root.remove(student); // 将内存中的Document会写到文件中 // Pretty print the document to System.out
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK"); // 创建一个xml的写入器. 构造函数中传入 写入的文件的位置和 格式化器
XMLWriter writer = new XMLWriter(
new FileOutputStream(new File("src/stu.xml")), format);
writer.write(document);
writer.close(); /** //创建一个xml的写入器. 构造函数中传入 写入的文件的位置 XMLWriter writer = new XMLWriter( new
* FileWriter( "src/student_copy.xml" ) ); // 写入什么 writer.write(
* document ); //关闭并释放资源 writer.close();
*/
}
}

6.整合Xpath

package cn.itcast.xml.dom4j;

import java.io.FileWriter;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class Demo5 {
// 修改一个学生.学号ITCAST_0001的学生年龄改为18
public static void main(String[] args) throws Exception {
SAXReader reader = new SAXReader();
Document document = reader.read("src/student.xml");
// 通过文档对象获得 根节点
Element root = document.getRootElement();
// 定义xpath表达式
String xpath = "//student[@number='ITCAST_0001']"; // 通过表达式 选取对应的元素
Element student = (Element) document.selectSingleNode(xpath); //修改
student.element("age").setText("18"); // 将内存中的Document会写到文件中 // Pretty print the document to System.out
OutputFormat format = OutputFormat.createPrettyPrint();
// 创建一个xml的写入器. 构造函数中传入 写入的文件的位置和 格式化器
XMLWriter writer = new XMLWriter(
new FileWriter("src/student_copy.xml"), format);
writer.write(document);
writer.close(); /*
* //创建一个xml的写入器. 构造函数中传入 写入的文件的位置 XMLWriter writer = new XMLWriter( new
* FileWriter( "src/student_copy.xml" ) ); // 写入什么 writer.write(
* document ); //关闭并释放资源 writer.close();
*/
}
}

XML的DOM、SAX、DEMO4J及DEMO4J整合Path的代码例子的更多相关文章

  1. JAVA解析XML文件(DOM,SAX,JDOM,DOM4j附代码实现)

    1.解析XML主要有四种方式 1.DOM方式解析XML(与平台无关,JAVA提供,一次性加载XML文件内容,形成树结构,不适用于大文件) 2.SAX方式解析XML(基于事件驱动,逐条解析,适用于只处理 ...

  2. 解析XML:DOM,SAX,PULL

    Android解析XML有三种方式:DOM(document object model).SAX(simple api XML).PULL 1.DOM DOM解析XML文件时,会将XML文件的所有内容 ...

  3. XML概念定义以及如何定义xml文件编写约束条件java解析xml DTD XML Schema JAXP java xml解析 dom4j 解析 xpath dom sax

    本文主要涉及:xml概念描述,xml的约束文件,dtd,xsd文件的定义使用,如何在xml中引用xsd文件,如何使用java解析xml,解析xml方式dom sax,dom4j解析xml文件 XML来 ...

  4. JavaScripts学习日记——DOM SAX JAXP DEMO4J XPath

    今日关键词: XML解析器 DOM SAX JAXP DEMO4J XPath XML解析器 1.解析器概述 什么是解析器 XML是保存数据的文件,XML中保存的数据也需要被程序读取然后使用.那么程序 ...

  5. 解析XML文件的几种常见操作方法—DOM/SAX/DOM4j

    解析XML文件的几种常见操作方法—DOM/SAX/DOM4j 一直想学点什么东西,有些浮躁,努力使自己静下心来看点东西,哪怕是回顾一下知识.看到了xml解析,目前我还没用到过.但多了解一下,加深点记忆 ...

  6. android解析XML总结(SAX、Pull、Dom三种方式) <转载>

    android解析XML总结(SAX.Pull.Dom三种方式) http://www.cnblogs.com/JerryWang1991/archive/2012/02/24/2365507.htm ...

  7. Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)

    [目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...

  8. Android 通过Dom, Sax, Pull解析网络xml数据

    这篇文章不是完全原创,XML解析的部分参考了 liuhe688 的文章.文章地址:http://blog.csdn.net/liuhe688/article/details/6415593 这是一个几 ...

  9. XML 解析---dom解析和sax解析

    眼下XML解析的方法主要用两种: 1.dom解析:(Document Object Model.即文档对象模型)是W3C组织推荐的解析XML的一种方式. 使用dom解析XML文档,该解析器会先把XML ...

随机推荐

  1. 解析xml的几种方式

    http://blog.csdn.net/smcwwh/article/details/7183869

  2. jQuery旋转插件

    jQuery旋转插件,支持Internet Explorer 6.0 + .Firefox 2.0.Safari 3.Opera 9.Google Chrome,高级浏览器下使用Transform,低 ...

  3. C++拾遗(七)函数相关(2)

    内联函数 内联函数与常规函数的区别在于: 1.常规函数:在执行调用指令时,先存储该指令的内存地址,将函数参数复制到堆栈,然后跳转到被调用函数起点的内存单元,执行函数,将返回值放 入寄存器,最后跳回到一 ...

  4. JS encode decode

    网上查到的全都是escape,和需要的编码不是一回事,好不容易找到的结果 保存下来以备以后使用 js对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent, ...

  5. IRP派遣操作

    IRPTrace工具跟踪IRP 派遣函数(Dispathc Funtion)是windows驱动中的重要概念.驱动程序的主要功能是负责处理I/O请求,其中大部分I/O请求是在派遣函数中处理的.用户模式 ...

  6. java 批量插入10万条数据

    for (int i = 0; i < 100000; i++) { dbHelper.insert("INSERT aaa(name) Values ('1')"); } ...

  7. Mssql显错和不显错模式下的注入

    Title:Mssql显错和不显错模式下的注入 -- 2010-10-27 19:51 近期用手工注入用习惯了,便列出最近用的Mssql语句,以后方便拿来用! -------------------- ...

  8. 技巧:Linux 动态库与静态库制作及使用详解

    技巧:Linux 动态库与静态库制作及使用详解 标准库的三种连接方式及静态库制作与使用方法 Linux 应用开发通常要考虑三个问题,即:1)在 Linux 应用程序开发过程中遇到过标准库链接在不同 L ...

  9. cf500D New Year Santa Network

    D. New Year Santa Network time limit per test 2 seconds memory limit per test 256 megabytes input st ...

  10. 什么是Ajax? (转载于疯狂客的BLOG)

    Ajax的定义 Ajax不是一个技术,它实际上是几种技术,每种技术都有其独特这处,合在一起就成了一个功能强大的新技术. Ajax包括: XHTML和CSS,使用文档对象模型(Document Obje ...