在java   jdk中解析XMl文件使用 org.w3c.dom.Document工具

一下是写入全程:

import java.io.File;
import java.io.IOException;
import java.io.StringWriter; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult; import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.xml.sax.SAXException; public class CreatXML { /**
* 创建一个XML文件
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub try { DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();//可获取XML解析器
DocumentBuilder builder = factory.newDocumentBuilder();//获取文档生成器
Document document=builder.newDocument();//获取文档实例
Element root=document.createElement("languages");//创建一个根元素
root.setAttribute("cat", "it");//给根元素添加一个cat="it" 的属性 Element lan1=document.createElement("lan");//创建一个元素标签名为<lan>
lan1.setAttribute("id", "1");//添加属性
Element name1=document.createElement("name");//创建一个name标签
name1.setTextContent("java");//为name标签设置内容
Element ide1=document.createElement("ide");//创建一个ide标签
ide1.setTextContent("Eclipse");//为表填添加内容 lan1.appendChild(name1);
lan1.appendChild(ide1);//让name1和 ide1标签成为lan1标签的子节点
root.appendChild(lan1);//将lan1添加到root 的子节点 document.appendChild(root);//将root添加到文档 //将document转化成流数据 以便储存在文件 或者传输 TransformerFactory transformerFactory= TransformerFactory.newInstance();
Transformer transformer=transformerFactory.newTransformer();
StringWriter writer=new StringWriter();
transformer.transform(new DOMSource(document), new StreamResult(writer));//将document转换成输出流
System.out.println(writer.toString()); transformer.transform(new DOMSource(document), new StreamResult(new File("newXML.xml")));//将document保存到文件 } catch (Exception e) {
e.printStackTrace();
} } }

  

以下是解析全程:

import java.io.File;

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.Node;
import org.w3c.dom.NodeList;
/**
* 解析xml文件
*
*
*/ public class ShowXML { public static void main(String[] args) throws Exception { DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();//可获取XML解析器
DocumentBuilder builder=factory.newDocumentBuilder();//获取文档生成器
Document document=builder.parse(new File("workspace.xml"));//获取文档
Element root=document.getDocumentElement();//获取文档元素(这里是主元素)
System.out.println("version="+root.getAttribute("version"));//输出查看元素属性
NodeList list=root.getElementsByTagName("component");//获取所有component标签节点
for (int i = 0; i < list.getLength(); i++) {//遍历节点
Element component=(Element) list.item(i);//获取节点
System.out.println("----------------------------------");
System.out.println("component"+i+".name="+component.getAttribute("name"));//输出节点元素属性
//System.out.println(component.getTextContent());//获取节点内的文本
NodeList list1=component.getChildNodes();//获取component元素的所有子元素
for (int j = 0; j < list1.getLength(); j++) {//遍历子元素
System.out.println("-----------------------------------------");
Node componentchild=list1.item(j);//获取子元素节点 System.out.println(componentchild.getNodeName());//输出子元素标签名
//System.out.println(componentchild.getTextContent());//输出子元素的文本内容
//输出中有些无用的节点#text 代表换行空白的节点
//去除#text的方法 判断这个节点是不是一个元素再输出
/*if(componentchild instanceof Element){
System.out.println(componentchild.getNodeName());//输出子元素标签名 }*/ } } }
}

  

还有一种引用Dom4j.jar 工具包

写入Xml

package Dom4j_XMl;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream; import org.dom4j.Document;
import org.dom4j.DocumentHelper; public class Dom4j { /**
* Dom4j使用 快捷的进行XML读写
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
String xmlval="<peopre><name>老表</name><age>26</age></peopre>";
Document document=DocumentHelper.parseText(xmlval); System.out.println(document.asXML());//直接可以输出XML格式的数据 File file=new File("mynews.xml");
if(!file.isAbsolute()){ file.createNewFile();
}
byte[] xmlbyte=xmlval.getBytes("utf-8"); FileOutputStream out=new FileOutputStream(file);
BufferedOutputStream bout=new BufferedOutputStream(out);
bout.write(xmlbyte);
bout.flush();
out.close();
bout.close(); } }

  

XML文件解析!!!的更多相关文章

  1. 通过正则表达式实现简单xml文件解析

    这是我通过正则表达式实现的xml文件解析工具,有些XHTML文件中包含特殊符号,暂时还无法正常使用. 设计思路:常见的xml文件都是单根树结构,工具的目的是通过递归的方式将整个文档树装载进一个Node ...

  2. 八、Android学习第七天——XML文件解析方法(转)

    (转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 八.Android学习第七天——XML文件解析方法 XML文件:exten ...

  3. android基础知识13:AndroidManifest.xml文件解析

    注:本文转载于:http://blog.csdn.net/xianming01/article/details/7526987 AndroidManifest.xml文件解析. 1.重要性 Andro ...

  4. Android之AndroidManifest.xml文件解析

    转自:Android学习笔记之AndroidManifest.xml文件解析 一.关于AndroidManifest.xml AndroidManifest.xml 是每个android程序中必须的文 ...

  5. 9.XML文件解析

    一.XML简介 XML(EXtensible Markup Language),可扩展标记语言 特点:XML与操作系统.编程语言的开发平台无关 实现不同系统之间的数据交换 作用:数据交互 配置应用程序 ...

  6. Python实现XML文件解析

    1. XML简介 XML(eXtensible Markup Language)指可扩展标记语言,被设计用来传输和存储数据,已经日趋成为当前许多新生技术的核心,在不同的领域都有着不同的应用.它是web ...

  7. Python3将xml文件解析为Python对象

    一.说明 从最开始写javascript开始,我就很烦感使用getElementById()等函数来获取节点的方法,获取了一个节点要访问其子孙节点要么child半天要么就再来一个getElementB ...

  8. XML文件解析-DOM4J方式和SAX方式

    最近遇到的工作内容都是和xml内容解析相关的. 1图片数据以base64编码的方式保存在xml的一个标签中,xml文件通过接口的方式发送给我,然后我去解析出图片数据,对图片进行进一步处理. 2.xml ...

  9. java基础之概谈xml文件解析

    XML已经成为一种非常通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便. 诸多web应用框架,其可配置的编程方式,给我们的开发带来了非常大程度的便捷,但细细 ...

  10. XML文件解析之JDOM解析

    1.JDOM介绍 JDOM的官方网站是http://www.jdom.org/,JDOM解析用到的jar包可以在http://www.jdom.org/dist/binary/中下载,最新的JDOM2 ...

随机推荐

  1. C语言_扫雷代码

    本文详细讲述了基于C语言实现的扫雷游戏代码,代码中备有比较详细的注释,便于读者阅读和理解.希望对学习游戏开发的朋友能有一点借鉴价值. 完整的实例代码如下: ? 1 2 3 4 5 6 7 8 9 10 ...

  2. Linux中文件查找,压缩和打包指令

    1.文件的查找和搜索 可执行文件的搜索:which .whereis locate搜索文件 find搜索文件       1.1可执行文件的搜索       在Linux系统中,有成百上千个指令,不同 ...

  3. BFPRT: O(n)最坏时间复杂度找第K大问题

    同时找到最大值与最小值 找到n个元素中的最大/小值,比较次数为n-1, 找到n个元素中的最大值和最小值,可以Two Pass,比较次数为2n-2 也可以One Pass,比较次数至多为\(\left ...

  4. GitHub上一些有趣的开源项目[持续更新]

    TheAlgorithms/C-Plus-Plus 用C++实现了常见的算法,如排序算法,查找算法,以及一些常见的数据数据结构,如链表,二叉树. 链接:https://github.com/TheAl ...

  5. Java基本的程序结构设计 整形和浮点型

    整形: int 4字节 short 2字节 long 8字节 byte 1字节 int的大小差不多是20亿. 整形计算 如果两个int进行加减乘除数学运算的时候,最终的结果仍然是int,有可能出现了溢 ...

  6. 查看mysql数据库容量大小

     第一种情况:查询所有数据库的总大小,方法如下: mysql> use information_schema; mysql> select concat(round(sum(DATA_LE ...

  7. try-catch-finally try中有rerun 是否执行finally

    finally块的语句在try或catch中的return语句执行之后返回之前执行且finally里的修改语句可能影响也可能不影响try或catch中 return已经确定的返回值,若finally里 ...

  8. vue 设置 input 为不可以编辑

    我用最笨的方法,先实现功能先,用两个input,一个可以编辑,一个不可以编辑,失去焦点后隐藏可以点击的那个,点"编辑"时,显示可以编辑的那个input <div class= ...

  9. postman—使用newman来执行postman脚本

    我们知道postman是基于javascript语言编写的,而导出的json格式的postman脚本也无法直接在服务器运行,它需要在newman中执行(可以把newman看做postman脚本的运行环 ...

  10. Python爬虫十六式 - 第三式:Requests的用法

    Requests: 让 HTTP 服务人类 学习一时爽,一直学习一直爽   Hello,大家好,我是Connor,一个从无到有的技术小白.今天我们继续来说我们的 Python 爬虫,上一次我们说到了 ...