XML:  可扩展标记语言(extensible Markup Language)

  用于标记电子文件使其具有结构性的标记语言。XML可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。

xml语言示例:

<?xml version ="1.0" encoding="utf-8" ?>     =》》这个必须要有
<persons>
  <person id="01">
    <name>李鹏</name>
    <age>22</age>
    <sex>男</sex>
  </person>
  <person id="02">
    <name>李四</name>
    <age>23</age>
    <sex>女</sex>
  </person>
</persons>

xml的解析方法:

1:SAX解析

  MyHandler类,负责解析xml文档将查找的值使用面向对象思想放在对象列表中==》必须要继承DefaultHandler类

package sax;

import java.util.ArrayList;
import java.util.List; import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler; public class MyHandler extends DefaultHandler
{
private List<Person> list;
private Person person;
private String tagName;//存储开始标签名字
//解析到文档开头时,执行该方法
@Override
public void startDocument() throws SAXException
{
list = new ArrayList<Person>();
} //解析到开始标签时,执行该方法,qName参数用来接收标签名字
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException
{
tagName = qName;
if("person".equals(qName))
{
person = new Person();
if(attributes !=null)
{
//解析标签中的内容 如:<person id="01"> 中的id
for(int i =0;i<attributes.getLength();i++)
{
String name = attributes.getQName(i);
String value = attributes.getValue(i);
if("id".equals(name))
{
person.setId(Integer.parseInt(value));
}
}
}
} }
//解析到标签内容时,执行该方法,解析到的标签内容传给了参数ch
@Override
public void characters(char[] ch, int start, int length)
throws SAXException
{
String str = new String(ch,start,length);
if("name".equals(tagName))
person.setName(str);
else if("age".equals(tagName))
person.setAge(Integer.parseInt(str));
else if("sex".equals(tagName))
person.setSex(str); }
//解析到结束标签时,执行该方法,qName接收标签名称
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException
{
tagName = null;//这里必须置空
if("person".equals(qName))
{
list.add(person);
} }
//解析到文档结束时,执行该方法
@Override
public void endDocument() throws SAXException
{ }
public List<Person> getList()
{
return list;
} }

Test类:负责建立解析器,建立解析器使用的读取类和读取流,读取到数据并显示在客户端,其中的HttpUtil类在上篇博客中有

package sax;

import java.io.IOException;
import java.io.InputStream;
import java.util.List; import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import org.xml.sax.SAXException; public class Test
{ public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException
{
//创建Sax解析工厂对象
SAXParserFactory factory = SAXParserFactory.newInstance();
//创建Sax解析器对象---具备解析功能的对象
SAXParser parser = factory.newSAXParser(); String path = "http://localhost:9999/day16/user2.xml";
//创建被解析的文件的读取流
InputStream in = HttpUtil.getInputStram(path);
//创建MyHandler对象
MyHandler handler = new MyHandler();
//解析器使用文件字节读取流读取文件,读取的过程中调用handler中的方法
parser.parse(in,handler);
//获取集合
List<Person> list = handler.getList(); for(Person per:list)
{
System.out.println(per);
}
} }

2:PULL解析 ==》直接返回解析得到的list列表

package PULL;

import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List; import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory; public class Pull
{
public static List<Person> pullParser(InputStream in)
throws XmlPullParserException, NumberFormatException, IOException
{
List<Person> list = null;
Person person = null;
//创建pull解析工厂类对象
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
//创建pull解析器对象
XmlPullParser parser = factory.newPullParser();
//创建被解析文件的读取流对象
InputStream input = in;
parser.setInput(input,"utf-8");
//把被解析的文件的读取流给解析器
//得到解析器返回的第一个编号
int event = parser.getEventType();
while (event != XmlPullParser.END_DOCUMENT)
{
switch (event)
{
case XmlPullParser.START_DOCUMENT:
list = new ArrayList<Person>();
break;
case XmlPullParser.START_TAG:
//得到解析到的标签名
String tagName = parser.getName();
if ("person".equals(tagName))
{
person = new Person();
int count = parser.getAttributeCount();
for (int i = 0; i < count; i++)
{
//直接得到开始标签后边的数据
String attrName = parser.getAttributeName(i);
String attrValue = parser.getAttributeValue(i);
if ("id".equals(attrName))
person.setId(Integer.parseInt(attrValue));
}
} else if ("age".equals(tagName))
person.setAge(Integer.parseInt(parser.nextText()));
else if ("sex".equals(tagName))
person.setSex(parser.nextText());
else if("name".equals(tagName))
person.setName(parser.nextText());
break;
case XmlPullParser.END_TAG:
if ("person".equals(parser.getName()))
list.add(person);
break;
}
//得到下一个编号
event = parser.next();
}
return list; } }

JAVA 中XML的解析的更多相关文章

  1. 转:在java中使用dom4j解析xml

    JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...

  2. Java中XML格式的字符串4读取方式的简单比较

    Java中XML格式的字符串4读取方式的简单比较 1.java自带的DOM解析. import java.io.StringReader; import javax.xml.parsers.Docum ...

  3. 第70节:Java中xml和tomcat

    第70节:Java中xml和tomcat 前言: 哭着也要看完,字数: jdbc crud - statement dao java.sql.Driver The interface that eve ...

  4. Java中XML数据

    Java中XML数据 XML解析——Java中XML的四种解析方式 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解 ...

  5. JAVA中生成、解析二维码图片的方法

    JAVA中生成.解析二维码的方法并不复杂,使用google的zxing包就可以实现.下面的方法包含了生成二维码.在中间附加logo.添加文字功能,并有解析二维码的方法. 一.下载zxing的架包,并导 ...

  6. 沉淀再出发:java中线程池解析

    沉淀再出发:java中线程池解析 一.前言 在多线程执行的环境之中,如果线程执行的时间短但是启动的线程又非常多,线程运转的时间基本上浪费在了创建和销毁上面,因此有没有一种方式能够让一个线程执行完自己的 ...

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

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

  8. XML解析——Java中XML的四种解析方式

    XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四 ...

  9. XML解析——Java中XML的四种解析方式(转载 by 龍清扬)

    XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四 ...

随机推荐

  1. TCP3次握手连接协议和4次握手断开连接协议

    TCP/IP 状态机,如下图所示: 在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接,如图1所示. (SYN包表示标志位syn=1,ACK包表示标志位ack=1,SYN+A ...

  2. SQL update join on 连接更新

    http:/how-can-i-do-an-update-statement-with-join-in-sql create table sale ( id int, udid int, assid ...

  3. [css 揭秘]-css coding tips

    css 揭秘之css coding tips demo(1) html 代码: <body> <section> <div class="demo1" ...

  4. 线性时间O(n)内求数组中第k大小的数

    --本文为博主原创,转载请注明出处 因为最近做的WSN(wireless sensor network)实验要求用3个传感器节点接受2000个包的数据并算出一些统计量,其中就有算出中位数这么一个要求, ...

  5. 轻量级ORM-Fluentdata入门

    Fluent Data 入门 由 Primates 根据互联网资源整理FluentData 是微型 ORM(micro-ORM)家族的一名新成员,旨在比大型 ORM(full ORM)更加易用.Flu ...

  6. idea使用心得(3)-重构初探

    上一篇idea心得中,介绍了快捷键的用法.其中提及了重构神器Alt+Ctrl+Shift+T , 当时只是稍稍提及,本文重点在idea提供的重构选项.后续会有<重构,改善既有代码的设计>的 ...

  7. mongoperf

    官方文档 mongoperf is a utility to check disk I/O performance independently of MongoDB. It times tests o ...

  8. Windows zabbix监控远程进程实现机制

    最近负责zabbix监控部署方面的工作,需要完成本地服务端监控远程虚拟机的运行状态(CPU.打开的进程等),与大家分享下我的实现方法. (1) 首先,需要实现记录zabbix客户端的进程的批处理:za ...

  9. myisam、innodb存储引擎比较

    MYSQL表类型(存储引擎) 1.概述 MySQL数据库其中一个特性是它的存储引擎是插件式的.用户可以根据应用需要选择存储引擎.Mysql默认支持多种存储引擎,以适用各种不同的应用需要.默认情况下,创 ...

  10. CentOS 7 yum方式配置LAMP环境

    环境:CentOS 7 最小化安装 采用Putty连接 方法:采用YUM安装方法 目的:搭建Apache+Mysql+PHP环境 1,安装Apache yum install httpd //默认情况 ...