- 浏览: 156823 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
zhangyatong:
zhangyatong 写道ws.getColumnView( ...
jxl处理图片 -
zhangyatong:
ws.getColumnView( bc ).getSize( ...
jxl处理图片 -
simple_hui:
a114d 写道楼主,创建xml的过程没看懂,这句
XMLWr ...
java dom4j操作xml -
a114d:
楼主,创建xml的过程没看懂,这句XMLWriter outp ...
java dom4j操作xml
一直用的dom4j解析,最近碰到工程里面是这种解析方式。
先记录下网上百度的一段代码。
写道
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class edit
{
public static void main(String[] args)
{
try{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
Document doc=builder.parse("links.xml");
doc.normalize();
NodeList books =doc.getDocumentElement().getChildNodes();
Node book;
NodeList lists;
book=books.item(1);
//添加节点
Element id=doc.createElement("id");
id.appendChild(doc.createTextNode("first"));
book.appendChild(id);
//删除节点
book.removeChild(book.getChildNodes().item(1));
//修改节点
Text sina=doc.createTextNode("sina");
book.getChildNodes().item(2).replaceChild(sina,book.getChildNodes().item(2).getFirstChild());
System.out.println(book.getChildNodes().item(2).getNodeName());
System.out.println(books.getLength());
System.out.println(book.getChildNodes().getLength());
//浏览查看
for(int i=1;i<books.getLength();i++)
{
book=books.item(i);
lists=book.getChildNodes();
for(int j=1;j<lists.getLength();j++)
{
if(lists.item(j).getNodeType()==Node.ELEMENT_NODE)
System.out.println(lists.item(j).getFirstChild().getNodeValue());
}
}
TransformerFactory tFactory =TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new java.io.File("links.xml"));
transformer.transform(source, result);
}catch(Exception e){System.out.println(e);}
}
}
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class edit
{
public static void main(String[] args)
{
try{
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
Document doc=builder.parse("links.xml");
doc.normalize();
NodeList books =doc.getDocumentElement().getChildNodes();
Node book;
NodeList lists;
book=books.item(1);
//添加节点
Element id=doc.createElement("id");
id.appendChild(doc.createTextNode("first"));
book.appendChild(id);
//删除节点
book.removeChild(book.getChildNodes().item(1));
//修改节点
Text sina=doc.createTextNode("sina");
book.getChildNodes().item(2).replaceChild(sina,book.getChildNodes().item(2).getFirstChild());
System.out.println(book.getChildNodes().item(2).getNodeName());
System.out.println(books.getLength());
System.out.println(book.getChildNodes().getLength());
//浏览查看
for(int i=1;i<books.getLength();i++)
{
book=books.item(i);
lists=book.getChildNodes();
for(int j=1;j<lists.getLength();j++)
{
if(lists.item(j).getNodeType()==Node.ELEMENT_NODE)
System.out.println(lists.item(j).getFirstChild().getNodeValue());
}
}
TransformerFactory tFactory =TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new java.io.File("links.xml"));
transformer.transform(source, result);
}catch(Exception e){System.out.println(e);}
}
}
-----------------------------------------------------------------------------------------------------
有如下的xml文档 <?xml version=”1.0”?> <font> <name>Helvetica</name> <size>36</size> </font> 遍历整个xml的所有node
XML文档时,解析器会得到5个结果:
写道
import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class XMLReader {
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException
{
File file = new File("test.xml");
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
//将xml文件解释成文档对象
Document doc = db.parse(file);
//取得文档根
doc.normalize();
Element root = doc.getDocumentElement();
//取得要元素名
System.out.println("The root element is:" + root.getNodeName());
//获取孩子节点
NodeList children = root.getChildNodes();
stepThrough(root);
}
private static void stepThrough (Node start)
{
for(Node child = start.getFirstChild();child != null;child = child.getNextSibling())
{
if(child instanceof Element)//去除多余的空白
{
System.out.print("节点名:"+child.getNodeName());
System.out.println("\t节点值:"+ child.getNodeValue());
}
if(child != null)
stepThrough(child);
}
}
}
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class XMLReader {
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException
{
File file = new File("test.xml");
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
//将xml文件解释成文档对象
Document doc = db.parse(file);
//取得文档根
doc.normalize();
Element root = doc.getDocumentElement();
//取得要元素名
System.out.println("The root element is:" + root.getNodeName());
//获取孩子节点
NodeList children = root.getChildNodes();
stepThrough(root);
}
private static void stepThrough (Node start)
{
for(Node child = start.getFirstChild();child != null;child = child.getNextSibling())
{
if(child instanceof Element)//去除多余的空白
{
System.out.print("节点名:"+child.getNodeName());
System.out.println("\t节点值:"+ child.getNodeValue());
}
if(child != null)
stepThrough(child);
}
}
}
在处理这个
<font>与<name>之间的空白区域
Name元素
</name>与<size>之间的空白区域
Size元素
</size>与</font>之间的空白区域
如果只希望得到子元素,那么你可以忽略空白字符:
xml文档节点
写道
for(int i = 0;i < children.getLength(); i++)
{
Node child = children.item(i);
if (child instanceof Element)
{
Element childElement = (Element)child;
......
}
}
{
Node child = children.item(i);
if (child instanceof Element)
{
Element childElement = (Element)child;
......
}
}
遍历整个
for(Node childNode = element.getFirstChild();childNode != null;childNode = childNode.getNextSibling())
{
......
}
遍历整个xml某节点的所有属性
写道
NameNodeMap attributes = element.getAttributes();
for (int i = 0;i<attributes.getLength();i++)
{
Node attribute = attributes.item(i);
String name = attribute.getNodeName();//获得属性名
String value = attribute.getNodeValue();//获得属性值
}
for (int i = 0;i<attributes.getLength();i++)
{
Node attribute = attributes.item(i);
String name = attribute.getNodeName();//获得属性名
String value = attribute.getNodeValue();//获得属性值
}
如果只想知道己知属性的值,只需用
String unit = element.getAttribute(“unit”);
发表评论
-
CC使用的记录
2012-09-22 22:17 0创建一个文件视图: 1.通过CC插件选择创建clearcase ... -
查看系统交换空间
2012-09-09 19:59 5039虚拟内存 内存在计算机中的作用很大,电脑中所有运行的程序都需 ... -
错误信息:DB2 SQL57016
2012-09-09 19:33 2176在对表load数据之后,表出现如下错误: DB2 SQL er ... -
20120909
2012-09-09 19:24 8121.把工程给打包 cd 工程的WEB-ROOT目录 jar - ... -
SQL性能优化
2012-01-09 20:24 911转载 http://www.cnblogs.com/roo ... -
flex 关于下载的相关收集
2012-09-09 19:24 1004在Actionscript 2及以前,要打开任何网址,只需调用 ... -
css li 不换行
2010-12-22 23:28 1855li 不换行 ------ 不换行的策略: ... -
ext相关
2010-12-22 23:19 1378Ext的grid列宽自动调整问题解决方案: 1.去除Ext ... -
eclipse打JAR包,并运行
2010-12-02 23:11 26178------------------------------- ... -
绝对路径与相对路径
2010-11-20 20:05 9091.基本概念 绝对路径:绝对路径就是你的主页上的文件或目录在硬 ... -
取数字和字母的随机数
2010-11-20 19:59 1250package com.slei.order; publi ... -
错误信息:与tomcat有关的异常错误
2010-11-20 19:56 13161.Unable to find a javac compil ... -
关于JS异步刷新
2010-11-20 19:49 10621.页面上<div id ="iframe&q ... -
树的js
2010-05-12 21:39 942在网上看到比较成熟的关于树的js都是dtree,google了 ... -
UltraEdit 使用技巧
2010-04-13 22:26 1436Tip 1: 如何去掉所编辑文 ... -
一点点记录
2010-04-02 17:47 9721.两个打印语句,语义上没错,可是执行时有什么问题? S ... -
java dom4j操作xml
2010-03-25 18:22 2376这是从网上找来的解析xml的文章 SAXReader rea ... -
循环Map
2010-03-24 14:53 2148根据JDK的新特性,用For循环Map,例如循环Map的Key ... -
java 的接口到底起什么作用
2010-03-12 17:11 1107我想,可能不止我一个人有这个疑问,所以,把它贴出来。 ... -
ChartDirector图形控件
2010-03-10 15:37 3561public void createChart(Cha ...
相关推荐
w3c-dom.jar 包 dom解析xml使用 包 免积分下载
首先,解析XML文件主要涉及`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`类。以下是一个简单的示例: 1. 创建`DocumentBuilderFactory`实例,它是生成`DocumentBuilder`对象的工厂类。 2. ...
在Java中,`org.w3c.dom`包提供了DOM解析XML的基础接口和类。以下是DOM解析XML的基本步骤: 1. 加载XML文档:首先,我们需要一个`DocumentBuilderFactory`实例来配置和创建`DocumentBuilder`,然后用`...
本篇文章将深入探讨Android中的DOM解析XML文件,包括其基本原理、实现步骤和一些实用技巧。 ### 1. DOM解析的基本概念 DOM解析是一种将XML文件转换为内存中对象模型的方法。它将XML文档视为一棵树,其中每个元素、...
Java DOM 解析 XML 实例是 Java 语言中常用的 XML 解析方法之一,使用 W3C 推荐的文档对象模型(Document Object Model,DOM)来解析 XML 文档。DOM 提供了一个树形结构的对象模型,通过遍历树形结构可以访问和操作 ...
首先,需要导入必要的包,包括 java.io、javax.xml.parsers、javax.xml.transform 和 org.w3c.dom 等。这些包提供了 XML 文档的解析和生成功能。 接下来,创建一个名为 XMLHandler 的类,该类中包含一个名为 create...
使用DOM解析XML的基本步骤如下: 1. **导入必要的库**:在Java中,DOM解析功能主要由`javax.xml.parsers`和`org.w3c.dom`包提供。因此,首先需要在代码中导入这些库: ```java import javax.xml.parsers....
1. **导入库**:使用DOM解析XML时,我们需要导入javax.xml.parsers和org.w3c.dom相关的库。例如: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; ...
标题“java_dom解析xml xml java”表明了本文档的主题是关于如何使用Java中的DOM技术来解析XML文件。 #### 描述分析 描述中提到这是一个适合新手入门的内容,并给出了一个简单的XML示例。该XML文档包含了一个`...
DOM解析XML是处理XML数据的一种常见方式,尤其在Java编程中广泛使用。下面我们将深入探讨DOM解析XML的相关知识点。 1. DOM解析原理: DOM解析器读取整个XML文件,将其转换为内存中的对象树,每个XML元素、属性、...
DOM(Document Object Model)是W3C组织推荐的一种解析XML的标准API,它将XML文档转换为一个可操作的对象树,使得开发者可以通过编程方式对XML文档进行读取、修改和创建。 在Java中,DOM解析主要通过`javax.xml....
例如,使用`DocumentBuilderFactory`创建`DocumentBuilder`,然后用`parse()`方法解析XML文件,最后通过`getElementsByTagName()`等方法访问节点。 2. SAX(Simple API for XML) 与DOM不同,SAX是基于事件驱动的...
在Android项目中,我们需要导入以下库以使用DOM解析XML: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c....
Java提供了多种解析XML的API,包括SAX(Simple API for XML)、DOM(Document Object Model)以及DOM4J。下面我们将详细探讨这些解析方式及其在实际开发中的应用。 1. SAX解析器: SAX是一种基于事件驱动的解析器,...
在Java中,我们可以使用`javax.xml.parsers.DocumentBuilderFactory`和`org.w3c.dom.Document`等类来实现DOM解析。以下是一个简单的示例: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax...
在Java中,DOM解析XML文件主要涉及到`javax.xml.parsers.DocumentBuilderFactory`和`javax.xml.parsers.DocumentBuilder`这两个类。首先,我们创建一个`DocumentBuilderFactory`实例,然后用它来获取一个`...
以下是一个简单的DOM解析XML文档的Java代码示例: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c.dom....
下面是一个简单的DOM解析XML文件的例子: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c.dom.NodeList; ...
Ø 1、DOM(org.w3c.dom) Ø “文档对象模型”方式,解析完的Xml将生成一个树状结构的对象。 Ø 2、SAX(org.xml.sax) Ø SimpleAPI for XML,以事件的形式通知程序,对Xml进行解析。 Ø 3、XMLPULL(org.xmlpull.v1) ...
一个xml的解析方法,供参考。 import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import org.xml.sax.InputSource;