- 浏览: 338523 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
zuoguoyao:
版主,有没有 ext数据互动的。。教程
Ext2.0教程一:Ext介绍以及 ext页面布局 -
NineInchNails:
谢谢分享:D
Ext2.0教程一:Ext介绍以及 ext页面布局 -
风雨故都:
liuming
ext 多文件上传控件 Ext.ux.UploadDialog 使用中的问题 -
yanjiarui:
下必须能下,就是卡了点
oracle11g下载Oracle 10g下载 Oracle 9i 下载 -
coolbaby1984514:
public int findMonkey(int n, in ...
约瑟夫问题 java
xml文件如下:
<smil xmlns="http://www.w3.org/2000/SMIL20/CR/Language">
<head>
<layout>
<root-layout height="100%" width="100%" />
<region id="Image" top="0" left="0" height="80%" width="100%"/>
<region id="Text" top="80%" left="0" height="20%" width="100%"/>
</layout>
</head>
<body>
<par dur = "5000ms">
<img region="Image" src="/contentlib/32/35/92/52.jpg"/>
<audio src="/contentlib/32/36/58.wav"/>
<text region="Text" src="/contentlib/1/3/29/12.txt"/>
</par>
</body>
</smil>
要解析出xml文件节点属性,比如 要得出 节点<img region="Image" src="/contentlib/32/35/92/52.jpg"/> 属性src的值(/contentlib/32/35/92/52.jpg)。
下面是源码,可以直接解析xml文件 ,和文件流。
package com.huawei.idea.mkt.common;
import java.io.InputStream;
import java.io.IOException;
import java.util.ArrayList;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.FactoryConfigurationError;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.xml.sax.SAXException;
/**
* <p>Description: xml解析类</p>
*
*/
public class XmlParser
{
private static DocumentBuilderFactory factory;
private static DocumentBuilder builder;
private Document doc;
private Element root;
private String fileName;
private InputStream inputstream;
/**
* 解析文件xml
* @param file String
*/
public XmlParser(String file)
{
if (file == null)
{
return;
}
this.fileName = file;
try
{
load();
}
catch (IOException ex)
{
ex.printStackTrace();
return;
}
}
/**
* 解析输入流xml
* @param input InputStream
*/
public XmlParser(InputStream input)
{
if (input == null)
{
return;
}
inputstream = input;
try
{
loadStream();
}
catch (IOException ex)
{
ex.printStackTrace();
return;
}
}
/**
* 获取XML文件中指定标签所对应的节点集合
* @param key String 标签名字
* @return ArrayList 指定标签对应的节点集
*/
public ArrayList findNodes(String key)
{
NodeList nodes = root.getElementsByTagName(key);
ArrayList nodeList = new ArrayList();
for (int i = 0; i < nodes.getLength(); i++)
{
nodeList.add(i, (Node) nodes.item(i));
}
return nodeList;
}
/**
* 初始化XML
* @throws IOException
*/
public void loadStream()
throws IOException
{
try
{
loadXMLParser();
doc = builder.parse(inputstream);
root = doc.getDocumentElement();
}
catch (IOException ex)
{
ex.printStackTrace();
}
catch (SAXException ex)
{
ex.printStackTrace();
}
finally
{
inputstream.close();
}
}
/**
* 初始化XML
* @throws IOException
*/
public void load()
throws IOException
{
try
{
loadXMLParser();
doc = builder.parse(fileName);
root = doc.getDocumentElement();
}
catch (SAXException SaxEx)
{
SaxEx.printStackTrace();
throw new IOException(SaxEx.getMessage() + "XML file parse error:"
+ SaxEx.getException());
}
catch (IOException IoEx)
{
IoEx.printStackTrace();
throw new IOException(IoEx.getMessage() + "XML file parse error:");
}
catch (Exception ex)
{
ex.printStackTrace();
throw new IOException(ex.getMessage() + "XML file parse error:");
}
}
/**
* 初始化XML
* @throws IOException
*/
private void loadXMLParser()
throws IOException
{
if (builder == null)
{
try
{
factory = DocumentBuilderFactory.newInstance();
builder = factory.newDocumentBuilder();
}
catch (ParserConfigurationException ex)
{
throw new IOException("XML Parser load error:"
+ ex.getLocalizedMessage());
}
catch (FactoryConfigurationError ConfErrEx)
{
throw new IOException("XML Parser load error:"
+ ConfErrEx.getLocalizedMessage());
}
catch (Exception Ex)
{
throw new IOException("XML Parser load error:"
+ Ex.getLocalizedMessage());
}
}
}
/**
* 获取XML文件中某级节点下一级元素的值
* @param node 节点对象
* @param subTagName subTagName元素的标签名
* @return String 该标记元素的的内容
*/
public static String getSubTagValue(Node node, String subTagName)
{
String returnString = "";
if ((node != null) && (subTagName != null))
{
NodeList children = node.getChildNodes();
for (int innerLoop = 0; innerLoop < children.getLength(); innerLoop++)
{
Node child = children.item(innerLoop);
if ((child != null) && (child.getNodeName() != null)
&& (child.getNodeName().equals(subTagName)))
{
Node grandChild = child.getFirstChild();
if (grandChild != null)
{
return grandChild.getNodeValue();
}
}
}
}
return returnString;
}
/**
* 获取XML文件中某单一值
* @param node 节点对象
* @param subTagName subTagName元素的标签名
* @return String 该标记元素的的内容
*/
public String getresult(String name)
{
String result = "";
ArrayList resultlist = findNodes(name);
if ((resultlist != null) && (resultlist.size() > 0))
{
for (int i = 0; i < resultlist.size(); i++)
{
Node node = (Node) resultlist.get(i);
if (node instanceof Element)
{
if ((node != null) && (node.getNodeName() != null)
&& (node.getNodeName().equals(name)))
{
Node grandChild = node.getFirstChild();
if (grandChild != null)
{
result = grandChild.getNodeValue();
}
}
}
}
}
return result;
}
//
public String getAttr(String name,String attrName)
{
String result = "";
ArrayList resultlist = findNodes(name);
if ((resultlist != null) && (resultlist.size() > 0))
{
for (int i = 0; i < resultlist.size(); i++)
{
Node node = (Node) resultlist.get(i);
if (node instanceof Element)
{
if ((node != null) && (node.getNodeName() != null)
&& (node.getNodeName().equals(name)))
{
//遍历整个xml某节点指定的属性
NamedNodeMap attrs=node.getAttributes();
if(attrs.getLength()>0 && attrs!=null)
{
Node attr=attrs.getNamedItem(attrName);
result=attr.getNodeValue();
}
}
}
}
}
return result;
}
public static void main(String[] args)
{
String file="D:\\common\\Tomcat60\\smil.smil";
XmlParser xml =new XmlParser(file);
System.out.println(xml.getAttr("text","src"));
}
}
发表评论
-
Apache Commons Launcher
2009-02-16 15:45 1814为百度百科编写的 词条 Apache Commons Laun ... -
领域驱动设计DDD
2009-04-14 09:20 1142Eric Evans所著的《领域驱动设计》(Domain-Dr ... -
领域驱动设计和开发实战
2009-04-17 09:32 1465领域驱动设计和开发实 ... -
JAVA Annotation 注解
2009-04-17 11:09 1540一、Annotation究竟是什么?Annotation 提供 ... -
作品展之---彩信积分系统(待续)
2009-05-09 10:45 652彩信积分系统 彩信积分系统,2009年4月开发 以 ... -
slf4j兼容commons-logging,log4j,java.util.logging,支持log4j.xml和log4j.properties配置
2009-07-01 10:05 3532最近在做一个集成,据说 log4j.xml 做日志配置文件将是 ... -
在数据库中存储层次数据实现无限级分层
2009-07-05 09:32 2276在数据库中存储层次数据实现无限级分层 无论你要构建自 ... -
约瑟夫问题 java
2009-07-17 11:03 4684约瑟夫问题 有M个人,其编号分别为1-M。这M个人按顺序排成 ... -
下载文件
2008-06-03 15:54 1495// 得到文件名字和路径 String fileName = ... -
编码转换 bat文件
2008-06-03 16:07 1661编码转换 bat文件 native2ascii -encodi ... -
转 Struts框架
2008-04-12 22:38 1072Struts框架 struts框架具有组件的模块化,灵 ... -
Struts标签使用示例
2008-04-13 01:34 3593html:multibox标签使用说 ... -
工作换了,技术也从新开始
2008-04-11 18:49 1094工作换了,技术也从新开始,可以上网了。做自己想做的事情,做自己 ...
相关推荐
本篇文章将深入探讨Android中的DOM解析XML文件,包括其基本原理、实现步骤和一些实用技巧。 ### 1. DOM解析的基本概念 DOM解析是一种将XML文件转换为内存中对象模型的方法。它将XML文档视为一棵树,其中每个元素、...
使用DOM解析XML的基本步骤如下: 1. **导入必要的库**:在Java中,DOM解析功能主要由`javax.xml.parsers`和`org.w3c.dom`包提供。因此,首先需要在代码中导入这些库: ```java import javax.xml.parsers....
通过使用 W3C DOM 接口,我们可以轻松地访问和操作 XML 文档中的元素和属性,从而实现了对 XML 文档的解析和处理。 四、结语 本文介绍了 Java 中的 DOM 解析 XML 实例,包括使用 DOM 解析 XML 文档的步骤、W3C DOM...
在Java中,`org.w3c.dom`包提供了DOM解析XML的基础接口和类。以下是DOM解析XML的基本步骤: 1. 加载XML文档:首先,我们需要一个`DocumentBuilderFactory`实例来配置和创建`DocumentBuilder`,然后用`...
首先,解析XML文件主要涉及`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`类。以下是一个简单的示例: 1. 创建`DocumentBuilderFactory`实例,它是生成`DocumentBuilder`对象的工厂类。 2. ...
在Android中,我们可以使用`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`等类来实现DOM解析。以下是一个简单的DOM解析XML文件的步骤: 1. 创建`DocumentBuilderFactory`实例: ```java ...
标题“java_dom解析xml xml java”表明了本文档的主题是关于如何使用Java中的DOM技术来解析XML文件。 #### 描述分析 描述中提到这是一个适合新手入门的内容,并给出了一个简单的XML示例。该XML文档包含了一个`...
这段代码展示了如何使用DOM解析XML,找到特定的元素并打印其属性和内容。 4. 性能优化: - 延迟加载(Lazy Loading):如果XML文件较大,可使用SAX解析器进行部分加载,避免一次性加载整个文档。 - 使用DOM4J或...
1. **导入库**:使用DOM解析XML时,我们需要导入javax.xml.parsers和org.w3c.dom相关的库。例如: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; ...
使用DOM解析XML的基本步骤如下: 1. 创建DocumentBuilderFactory实例。 2. 使用DocumentBuilderFactory创建DocumentBuilder实例。 3. 使用DocumentBuilder的parse()方法解析XML文件,得到Document对象。 4. 通过...
在Java中,DOM解析XML文件主要涉及到`javax.xml.parsers.DocumentBuilderFactory`和`javax.xml.parsers.DocumentBuilder`这两个类。首先,我们创建一个`DocumentBuilderFactory`实例,然后用它来获取一个`...
以下是一个使用Java DOM解析XML文件的示例代码片段: ```java import java.io.InputStream; import java.util.ArrayList; import java.util.List; import javax.xml.parsers.DocumentBuilder; import javax.xml....
【DOM解析XML】 在Java中,解析XML文档有多种方式,其中DOM(Document Object Model)和SAX(Simple API for XML)是最常见的两种。DOM是一种基于树形结构的XML处理方式,它将整个XML文档加载到内存中,形成一个完整...
在"XML解析之DOM"这一主题中,我们将深入探讨DOM解析器如何工作,以及如何通过DOM API获取XML文件中的信息。DOM解析器将整个XML文档加载到内存中,形成一个节点树,每个元素、属性、文本等内容都对应一个节点。这种...
在Java编程环境中,解析XML文件是一项常见的任务,特别是在数据处理和集成中。XML(Extensible Markup Language)是一种结构化数据格式,广泛用于存储和传输数据。本教程将介绍如何使用Java解析XML文件,并将解析...
在Android项目中,我们需要导入以下库以使用DOM解析XML: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c....
DOM解析器的优点在于提供了一种灵活且易于使用的API,可以方便地进行添加、删除和修改XML内容。以下是一个DOM解析的例子: ```java import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document...
首先,我们需要导入Java的`javax.xml.parsers`和`org.w3c.dom`包,它们提供了DOM解析XML所需的类和接口。 ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; ...
XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于数据交换、配置文件、文档存储等领域。在处理XML文档时,有三种主要的解析...根据具体的应用场景和需求,开发者可以选择合适的XML解析方法。
DOM解析器将整个XML文件加载到内存中,形成一个树形结构,可以方便地遍历和修改XML文档的任何部分。然而,由于它需要一次性加载整个文件,对于大文件来说可能会消耗大量内存。 在"ReadXMLDemo"中,使用DOM解析的...