/**
* 读取(解析)xml文件
* @author Administrator
*
*/
public class DOMRead {
public static void main(String[] args) throws Exception{
File file=new File("e:\\contact.xml");
InputStream in=new FileInputStream(file);
//创建DocuemntBuilderFactory实例化对象
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
//通过DocumentBuilderFactory实例化对象来创建DocumentBuilder对象
DocumentBuilder db=dbf.newDocumentBuilder();
//通过DocumentBuilder实例化对象 解析方法 来获取Document对象
Document document=db.parse(in); //通过document对象来获取指定tagName的所有标签元素
NodeList memberList = document.getElementsByTagName("member");
for(int i=0;i<memberList.getLength();i++){
//获取指定索引的标签元素
Element ele =(Element) memberList.item(i);
//获取标签元素的属性
String id = ele.getAttribute("id");
String name = ele.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
String phone = ele.getElementsByTagName("phone").item(0).getFirstChild().getNodeValue();
System.out.println("id="+id+",name="+name+",phone="+phone);
}
}
} /**
* 输出(创建)xml文件
* @author Administrator
*
*/
public class DOMWrit {
public static void main(String[] args) throws Exception {
File outFile=new File("e:"+File.separator+"book.xml"); DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
//通过DocumentBuilder实例化对象 创建方式 来获取Document对象
Document document=db.newDocument(); //创建根节点books
Element booksElement=document.createElement("books");
String[] title=new String[]{"三国演义","红楼梦","水浒传"};
Double[] price=new Double[]{99.9,88.8,77.7}; for(int i=0;i<title.length;i++){
//创建book节点
Element bookElt=document.createElement("book");
//创建title、price节点
Element titleElt=document.createElement("title");
Element priceElt=document.createElement("price");
//设置title节点的内容,需要创建文本节点
titleElt.appendChild(document.createTextNode(title[i]));
//设置price节点的内容,需要创建文本节点
priceElt.appendChild(document.createTextNode(String.valueOf(price[i]))); //将title、price节点添加到book节点中
bookElt.appendChild(titleElt);
bookElt.appendChild(priceElt); //将book节点添加到books根节点中
booksElement.appendChild(bookElt);
}
//遗忘的步骤
//将根节点设置到Document之中
document.appendChild(booksElement); //将DOM树转换为xml进行输出
TransformerFactory transformerfactory=TransformerFactory.newInstance();
Transformer transformer=transformerfactory.newTransformer(); //设置输出的元素
Source xmlSource=new DOMSource(document); Result outputTarget=new StreamResult(outFile); transformer.setOutputProperty(OutputKeys.ENCODING,"UTF-8");
//输出
transformer.transform(xmlSource, outputTarget); }
}

DOM-XML(解析与创建)的更多相关文章

  1. XML解析和创建的JAXB方式

    1.说明 JAXB是Java Architecture for XML Binding, 即用于XML绑定的Java体系结构, JAXB作为JDK的一部分, 能便捷地将Java对象与XML进行相互转换 ...

  2. java dom xml解析和windows dom解析的差别

    1.java dom 子节点包括空节点. 2.java dom 文档节点值也是其的子节点. 而windows dom(mshtml.dll)子节点不包括空节点,而节点值也不是以子节点的方式来对待的.

  3. Java&Xml教程(二)使用DOM方式解析XML文件

    DOM XML 解析方式是最容易理解的,它將XML文件作为Document对象读取到内存中,然后你可以轻松地遍历不同的元素和节点对象.遍历元素和节点不需要按照顺序进行. DOM解析方式适合尺寸较小的X ...

  4. 复习知识点:XML解析数据,JOSN解析数据,GET请求数据,POST请求数据

    GDataXMLDocument-XML解析 #pragma mark - ======== Dom XML解析 - (IBAction)domParserActionXML_Document:(id ...

  5. XML:使用DOM技术解析xML文件中的城市,实现select级联选择

    中国的城市xml格式:cities.xml <?xml version="1.0" encoding="utf-8"?> <china> ...

  6. xml的解析与创建——bing到youdao导入文件的转换

    首先是为了解决一个问题:如何将必应单词本中记录的单词转入到有道词典中去.实际上,必应词典可以导出xml文件,但是该文件有道词典无法解析.这里涉及到xml的解析和创建了. 代码如下: import ja ...

  7. XML解析之DOM详解及与SAX解析方法的比较

    XML解析(DOM) XML文件解析方法介绍 我们所用到的NSXMLParser是采用SAX方法解析 SAX(Simple API for XML) 只能读,不能修改,只能顺序访问,适合解析大型XML ...

  8. 初学DOM树解析xml文件

    做了一次设计模式实验的题目: 某软件公司为新开发的智能手机控制与管理软件提供了一键备份功能,通过该功能可以将原本存储在手机中的通信录.短信.照片.歌曲等资料一次性全部拷贝到移动存储介质(例如MMC卡或 ...

  9. 【Java】XML解析之DOM

    DOM介绍 DOM(Document Object Model)解析是官方提供的XML解析方式之一,使用时无需引入第三方包,代码编写简单,方便修改树结构,但是由于DOM解析时是将整个XML文件加载到内 ...

  10. DOM方式解析XML文件实例

    books.XML文件: <?xml version="1.0" encoding="utf-8"?><bookstore>    &l ...

随机推荐

  1. .net基础初学Android

    第一阶段:Java面向对象编程 1.Java基本数据类型与表达式,分支循环. 2.String和StringBuffer的使用.正则表达式. 3.面向对象的抽象,封装,继承,多态,类与对象,对象初始化 ...

  2. 使用IDEA进行打包

    使用IDEA打jar包: 1.

  3. CRF条件随机场

    CRF的进化 https://flystarhe.github.io/2016/07/13/hmm-memm-crf/参考: http://blog.echen.me/2012/01/03/intro ...

  4. 蛮力法解决0_1背包问题新思路-——利用C语言位域类型

    废话不说了,直接上代码 #include<stdio.h> #include<math.h> #define N 5 //物品种类数目 #define CAPACITY 6 / ...

  5. javaweb笔记二

    web服务器:实现服务器的开启,监听端口,接收客户端请求,产生响应.响应信息只能是静态的HTML,缺乏灵活性.web容器:是辅助应用的一种方式,是为了解决web服务器缺陷而产生的.可以将请求信息处理完 ...

  6. Ubuntu 16.04 使用docker资料汇总与应用docker安装caffe并使用Classifier(ros kinetic+usb_cam+caffe)

    Docker是开源的应用容器引擎.若想简单了解一下,可以参考百度百科词条Docker.好像只支持64位系统. Docker官网:https://www.docker.com/ Docker - 从入门 ...

  7. MFC+WinPcap编写一个嗅探器之六(分析模块)

    这一节是程序的核心,也是最复杂的地方 首先需要明白的一点是,一般对于一个有界面的程序来说,往往需要多线程.本程序中除了界面线程外,抓包需要另外创建一个新的线程.在写抓包函数之前,首先要将前面两个模块的 ...

  8. 解决ASP.NET MVC(post数据)Json请求太大,无法反序列化(The JSON request was too large to be deserialized)

    这个问题出现的场景并不是很多,当你向服务端异步(ajax)post数据非常大的情况下(比如做权限管理的时候给某个角色分配权限那么就可能会出现,我所遇到的就是该角色大概200个模块每个模块平均2个功能- ...

  9. jsp页面中注释 <!-- --> 和<%-- --%> 的区别

    jsp页面中注释 <!-- --> 和<%-- --%> 的区别 原创 2016年09月01日 17:55:44 标签: jsp注释 5605 今天发现一个问题:在jsp代码中 ...

  10. Java人员正确使用 IntelliJ IDEA的方式

    原文: http://tengj.top/2017/02/22/idea1-1/ 作者: 嘟嘟MD 前言 博主是Java开发人员,以前一直都用myeclipse来开发的,说实话感觉myeclipse毫 ...