schema文件及XML文件的DOM和Sax解析
schema文件
<?xml version="1.0" encoding="UTF-8"?>
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.example.org/book"
xmlns:book="http://www.example.org/book"
elementFormDefault="qualified">
<!--创建books根元素-->
<element name="books">
<complexType>
<sequence>
<element name="book" maxOccurs="unbounded" minOccurs="1">
<complexType>
<sequence>
<element name="name" type="string"/>
<element name="author" type="string" maxOccurs="2"/>
<element name="price" type="decimal"/>
<element name="date" type="date"/>
<element name="pageNumbers" type="int" minOccurs="0" maxOccurs="2"/>
</sequence>
<attribute name="id" type="ID" use="required"/>
<attribute name="name" type="string"/>
</complexType>
</element>
</sequence>
</complexType>
</element>
</schema>
<?xml version="1.0" encoding="UTF-8"?>
<books xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.example.org/book"
xmlns:book="http://www.example.org/book"
xsi:schemaLocation="http://www.example.org/book book.xsd">
<book:book id="CSN001" name="图书1">
<book:name></book:name>
<book:author>图书作者1</book:author>
<book:author>图书作者</book:author>
<book:price>66.6</book:price>
<book:date>1966-10-22</book:date>
<book:pageNumbers>1</book:pageNumbers>
</book:book>
</books>
xml解析
<?xml version="1.0" encoding="UTF-8"?>
<dataSources>
<!-- 定义MySQL数据源 -->
<dataSource id="mysql" class="xxx.xxx.xx">
<property name="driverClassName">com.mysql.jdbc.Driver</property>
<property name="url">jdbc:mysql://127.0.0.1:3306/userdb</property>
<property name="username">root</property>
<property name="password">123</property>
</dataSource> <!-- 定义Oracle的数据源 -->
<dataSource id="oracle" class="xxx.xxx.xx">
<property name="driverClassName">com.oracle.jdbc.OracleDriver</property>
<property name="url">jdbc:oracle:thin:@127.0.0.1:1521:ORCL</property>
<property name="username">scott</property>
<property name="password">tiger</property>
</dataSource>
</dataSources>
package com.demo.dom; import java.io.InputStream; 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; /**
* 使用DOM解析XML文件
*
* 把XML文件转换后为流程在把流在内存中构建一个DOM模型,使用对应API操作DOM树
*
* @author Administrator
*
*/
public class DOMParser { public static void main(String[] args) {
long start = System.nanoTime();
try {
// 创建一个文档构建工厂对象
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
// 通过工厂对象创建一个文档构建对象
DocumentBuilder documentBuilder = builderFactory.newDocumentBuilder();
// 吧XML转换为输入流操作
InputStream inputStream = DOMParser.class.getClassLoader().getResourceAsStream("datasource.xml");
// 通过文档构建对象构建一个文档对象
Document document = documentBuilder.parse(inputStream);
// 获取文档中的根元素
Element rootElement = document.getDocumentElement();
// 获取根元素先所有dataSource子节点
NodeList nodeList = rootElement.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) {
/**
* 3: 换行节点->文本节点 8: 注释节点 1: 元素节点
*/
Node node = nodeList.item(i);
// 判断元素节点才操作
if (Node.ELEMENT_NODE == node.getNodeType()) {
// 读取属性节点的值
String clazz = node.getAttributes().getNamedItem("class").getNodeValue();
String id = node.getAttributes().getNamedItem("id").getNodeValue();
System.out.println("class="+clazz);
System.out.println("id="+id);
// 获取元子节点
NodeList datasourceNodes = node.getChildNodes();
for (int j = 0; j < datasourceNodes.getLength(); j++) {
Node dataSourceNode = datasourceNodes.item(j); if (Node.ELEMENT_NODE == dataSourceNode.getNodeType()) {
// 获取属性的值
String nameValue = dataSourceNode.getAttributes().getNamedItem("name").getNodeValue();
String contentValue = dataSourceNode.getTextContent();
System.out.println(nameValue+"="+contentValue);
}
}
}
} } catch (Exception e) {
e.printStackTrace();
} long end = System.nanoTime();
System.out.println(end - start);
} }
package com.demo.sax; import java.io.InputStream; import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; import com.demo.dom.DOMParser; /**
* Sax解析
*
* @author Administrator
*
*/
public class SaxParserDemo {
public static void main(String[] args) {
long start = System.nanoTime();
// 创建一个Sax工厂对象->工厂设计
SAXParserFactory factory = SAXParserFactory.newInstance();
try {
// 创建解析器
SAXParser saxParser = factory.newSAXParser();
// 吧XML转换为输入流操作
InputStream inputStream = DOMParser.class.getClassLoader().getResourceAsStream("datasource.xml");
saxParser.parse(inputStream, new DefaultHandler() {
//解析开始标题文档
public void startDocument() throws SAXException {
System.out.println("<?xml version= 1.0 encoding= utf-8 ?>");
}
//解析节点
@Override
public void startElement(String uri, String localName,
String qName, Attributes attributes) throws SAXException {
System.out.print("<"+qName+" ");
for (int i = 0; i < attributes.getLength(); i++) {
System.out.print(attributes.getQName(i)+"="+attributes.getValue(i)+" ");
}
System.out.print(">");
} @Override
//解析结束
public void endElement(String uri, String localName, String qName)
throws SAXException {
System.out.print("</"+qName+">");
} @Override
//解析内容
public void characters(char[] ch, int start, int length)
throws SAXException {
String string = new String(ch, start, length);
System.out.print(string);
} });
} catch (Exception e) {
e.printStackTrace();
}
long end = System.nanoTime();
System.out.println(end - start);
} /**
* 定义默认处理的内部类
* @author Administrator
*
*/
private static class XMLHanlder extends DefaultHandler { @Override
public void startDocument() throws SAXException {
System.out.println("解析开始");
} @Override
public void startElement(String uri, String localName, String qName, Attributes attributes)
throws SAXException {
System.out.println("开始解析元素"+qName);
System.out.println(attributes.getValue("id"));
System.out.println(attributes.getValue("class"));
} @Override
public void endElement(String uri, String localName, String qName) throws SAXException {
System.out.println("解析结束");
} @Override
public void characters(char[] ch, int start, int length) throws SAXException {
System.out.println("解析内容");
System.out.println(new String(ch,start, length));
} }
}
schema文件及XML文件的DOM和Sax解析的更多相关文章
- XML - 十分钟了解XML结构以及DOM和SAX解析方式
引言 NOKIA 有句著名的广告语:"科技以人为本".不论什么技术都是为了满足人的生产生活须要而产生的.详细到小小的一个手机.里面蕴含的技术也是浩如烟海.是几千年来人类科技的结晶, ...
- JavaEE实战——XML文档DOM、SAX、STAX解析方式详解
原 JavaEE实战--XML文档DOM.SAX.STAX解析方式详解 2016年06月22日 23:10:35 李春春_ 阅读数:3445 标签: DOMSAXSTAXJAXPXML Pull 更多 ...
- LINQ to XML 从逗号分隔值 (CSV) 文件生成 XML 文件
参考:http://msdn.microsoft.com/zh-cn/library/bb387090.aspx 本示例演示如何使用 语言集成查询 (LINQ) 和 LINQ to XML 从逗号分隔 ...
- web端自动化——Python读取txt文件、csv文件、xml文件
1.读取txt文件 txt文件是我们经常操作的文件类型,Python提供了以下几种读取txt文件的方式. 1)read(): 读取整个文件. 2)readline(): 读取一行数据. 3)readl ...
- 关于跨域策略文件crossdomain.xml文件
下载flexpaper源码修改后做成swf阅读器,要加入待阅读的swf文件,可以在flex里调用js的方法来获取swf文件的路径的方法,在js只专注获取路径就行,等着flex来调用:但这里会遇到一个问 ...
- iOS开发中XML的DOM和SAX解析方法
一.介绍 dom是w3c指定的一套规范标准,核心是按树形结构处理数据,dom解析器读入xml文件并在内存中建立一个结构一模一样的“树”,这树各节点和xml各标记对应,通过操纵此“树”来处理xml中的文 ...
- Java SE之XML<二>XML DOM与SAX解析
[文档整理系列] Java SE之XML<二>XML DOM与SAX解析 XML编程:CRUD(Create Read Update Delete) XML解析的两种常见方式: DOM(D ...
- java基础71 XML解析中的【DOM和SAX解析工具】相关知识点(网页知识)
本文知识点(目录):本文下面的“实例及附录”全是DOM解析的相关内容 1.xml解析的含义 2.XML的解析方式 3.xml的解析工具 4.XML的解析原理 5.实例 6 ...
- Java文件操作①——XML文件的读取
一.邂逅XML 文件种类是丰富多彩的,XML作为众多文件类型的一种,经常被用于数据存储和传输.所以XML在现今应用程序中是非常流行的.本文主要讲Java解析和生成XML.用于不同平台.不同设备间的数据 ...
随机推荐
- 用Latex做介绍自己和团队科研的网页
最近实验室师妹用网上的一些模板改了改做了几个网页.感觉还可以.但是实际上总觉得好像和韩家炜.周志华他们的页面差点什么. 最近找论文时发现奥地利的hornik老先生页面居然latex做的,然后找到了下面 ...
- Pyhton学习——Day4
'''y=2*x+1x=3y->7x=3y->7'''# def test(x):# '''# 2*x+1# :param x:整形数字# :return: 返回计算结果# '''# y= ...
- Day 03 知识点[python程序运行的方式、变量、注释、内存管理、数据类型]
执行Python程序的两种方式 第一种:交互式,在cmd中运行 优点:调试程序方便,直接给出结果 缺点:无法保存,关掉cmd窗口数据就消失 第二种:命令行式通过cmd中输入Python3文本 优点:数 ...
- HDU 5533 Dancing Stars on Me( 有趣的计算几何 )
链接:传送门 题意:给出 n 个点,判断能不能构成一个正 n 边形,这 n 个点坐标是整数 思路:这道题关键就在与这 n 个点坐标是正整数!!!可以简单的分析,如果 n != 4,那一定就不能构成正 ...
- 使用python备份指定目录并删除备份超过一定时长的文件
#!/usr/bin/env python #-*- coding: utf-8 -*- """ @Project:Py @author: @Email: @Softwa ...
- 小学生都能学会的python(生成器)
小学生都能学会的python(生成器) 1. 生成器 生成器的本质就是迭代器. 生成器由生成器函数来创建或者通过生成器表达式来创建 # def func(): # lst = [] # for i i ...
- VUE:条件渲染和列表渲染
条件渲染 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- STM32 抢占优先级和响应优先级
一.抢占优先级和响应优先级 STM32 的中断向量具有两个属性,一个为抢占属性,另一个为响应属性,其属性编号 越小,表明它的优先级别越高. 抢占,是指打断其他中断的属性,即因为具有这个属性会出现嵌套中 ...
- webpack实战---安装操作
什么是webpack? 他有什么优点? 首先对于很多刚接触webpack人来说,肯定会问webpack是什么?它有什么优点?我们为什么要使用它? Webpack是前端一个工具,可以让各 ...
- NYIST 973 天下第一
天下第一时间限制:1000 ms | 内存限制:65535 KB难度:3 描述AC_Grazy一直对江湖羡慕不已,向往着大碗吃肉大碗喝酒的豪情,但是“人在江湖漂,怎能 不挨刀",”人在江湖身 ...