XML是一种可扩展的标记语言,可扩展就是<>内的东西可以自己定义,可以随便写。标记语言就是加了<>符号的 。HTML是超文本标记语言,不可以拓展,因为你写个<p> 浏览器知道这个是段落,你写个<shuyunquan>浏览器就不认识了,所以不可拓展

讲讲xml的书写格式:

1.开头固定

2.只能有一个根元素

3.没了

<?xml version="1.0" encoding="UTF-8"?>
<Students>
<student>
<name>许嵩</name>
<age>32</age>
</student>
<student>
<name>蜀云泉</name>
<age>23</age>
</student>
</Students>

我写了一个,开头的第一行是固定的,当然也可以多写。这个是告诉别人,我是xml文件

下面来介绍一下Java是怎么操作xml的,也可以说是怎么操作DOM的,以前一直听说DOM,Dom就是不知道是什么,原来DOM就是内存中的一个树形结构的数据称谓,xml的数据就是树形结构的,在内存中就是DOM

这篇文章只是介绍一下,具体操作处理XML文件还是要使用Dom4j,看这篇文章

一、Java读取xml

比如上面的xml文件,我想获取第二个student元素的name里面的文本,操作如下:

    private File f=new File("F:/Study Java/ch1helloworld/src/main/java/com/StadyJava/day2/xmldemo.xml");

    public void testDocument() throws ParserConfigurationException, IOException, SAXException {
//1.
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
//2.
DocumentBuilder builder=factory.newDocumentBuilder();
//3 经过这3步获取到了文档
Document doc=builder.parse(f); //上面的三步可以写成这样
//Document doc=DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(f); //已经获取了文档对象,现在获取xml的根元素
Element root=doc.getDocumentElement(); //获取第二个student 因为返回的是父类型Node,所以需要强转一下
Element student2=(Element) root.getElementsByTagName("student").item(1); //获取第二个student元素的子元素name
Element name2=(Element) student2.getElementsByTagName("name").item(0); //获取name元素的文本内容
System.out.println(name2.getTextContent()); }

1.获取xml文件

2.获取根元素students

3.获取根元素下面的第二个student元素

4.获取第二个student元素的name元素

5.获取name的文本内容

二、Java更改xml

这里我们准备把许嵩的年龄改为18

其实操作和上面的读取差不多,只不过多了一个从内存更新到磁盘的步骤

 public void setxml() throws  Exception {

        //获取文档对象
Document doc=DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(f); //已经获取了文档对象,现在获取xml的根元素
Element root=doc.getDocumentElement(); //获取第一个student 因为返回的是父类型Node,所以需要强转一下
Element student1=(Element) root.getElementsByTagName("student").item(0); //获取第一个student元素的子元素age
Element age1=(Element) student1.getElementsByTagName("age").item(0); //更新age元素的文本内容,这里仅仅的更新了内存中的DOM,还要更新到磁盘的xml源文件
age1.setTextContent("18"); //同步内存中的数据到磁盘中的源文件
Transformer trans=TransformerFactory.newInstance().newTransformer();
Source xmlSource=new DOMSource(doc); //内存中的DOM
Result outputTarget=new StreamResult(f); //磁盘中的xml文件
trans.transform(xmlSource,outputTarget);//从内存更新到磁盘 }

三、Java插入xml数据

要插入新数据,要创建元素,要给元素赋值,要给元素之间绑定关系

public void Insertxml() throws Exception{
//获取文档对象
Document doc=DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(f); //已经获取了文档对象,现在获取xml的根元素
Element root=doc.getDocumentElement(); //创建一个student元素以及子元素,注意,子元素和student之间还需要绑定
Element student=doc.createElement("student");
Element name=doc.createElement("name");
Element age=doc.createElement("age");
//给student元素赋值
name.setTextContent("林俊杰");
age.setTextContent("33");
//把子元素和student之间进行绑定
student.appendChild(name);
student.appendChild(age);
//把student元素和DOM的root根节点绑定起来
root.appendChild(student); //更新
Transformer trans=TransformerFactory.newInstance().newTransformer();
Source xmlSource=new DOMSource(doc); //内存中的DOM
Result outputTarget=new StreamResult(f); //磁盘中的xml文件
trans.transform(xmlSource,outputTarget);//从内存更新到磁盘
}

就是这样,代码更改的就中间那一段。新增数据后是没有空格格式的,所以数据都在一行,看起来不美观

四、Java删除xml元素

还是,先操作DOM,然后再更新到磁盘

 public void deletexml() throws Exception {
//获取文档对象
Document doc=DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(f);
//已经获取了文档对象,现在获取xml的根元素
Element root=doc.getDocumentElement();
//获取要删除的元素,记得强转
Element student=(Element) root.getElementsByTagName("student").item(2);
//删除
root.removeChild(student);
//同步操作
Transformer trans=TransformerFactory.newInstance().newTransformer();
Source xmlSource=new DOMSource(doc); //内存中的DOM
Result outputTarget=new StreamResult(f); //磁盘中的xml文件
trans.transform(xmlSource,outputTarget);//从内存更新到磁盘 }

Java中的XML的更多相关文章

  1. java中拼写xml

    本文为博主原创,未经博主允许,不得转载: xml具有强大的功能,在很多地方都会用的到.比如在通信的时候,通过xml进行消息的发送和交互. 在项目中有很多拼写xml的地方,进行一个简单的总结. 先举例如 ...

  2. Java中的Xml配置文件(新手)

    Java中的Xml配置文件,本文是转发转发转发!重要的事情说三遍 一:概念 1.XML  Extensible markup Language 可拓展标记语言 2.功能:存储数据(配置文件,在网络中传 ...

  3. java中的xml与实体类之间的映射

    实体类: package xml; import javax.xml.bind.annotation.XmlRootElement; @XmlRootElement public class User ...

  4. java 中解析xml的技术

    最初,XML 语言仅仅是意图用来作为 HTML 语言的替代品而出现的,但是随着该语言的不断发展和完善,人们越来越发现它所具有的优点:例如标记语言可扩展,严格的语法规定,可使用有意义的标记,内容存储和表 ...

  5. Java中解析XML的四种方法

    XML现在已经成为一种通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.对于XML本身的语法知识与技术细节,需要阅读相关的技术文献,这里面包括的内容有DOM ...

  6. java中调用xml的方法:DocumentBuilderFactory

    具体的使用方法如下: (1)得到 DOM 解析器的工厂实例 DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance(); (2 ...

  7. Java中读取xml方法

    package zaxiang; import java.io.*; import javax.xml.parsers.DocumentBuilder; import javax.xml.parser ...

  8. Java中的XML操作

    1.DOM方式解析(读取)XML文件 待解析(读取)的XML文件,直接放在项目根目录下即可 <?xml version="1.0" encoding="UTF-8& ...

  9. [j2ee]java中的xml操作

    一.XML简单介绍      xml是可扩展标记语言,主要用来标记数据.定义数据类型,很适合万维网传输. xml特点: xml是一种标记语言.非常类似HTML xml的设计宗旨是数据传输,而不是显示数 ...

随机推荐

  1. 字符串哈希及KMP

    字符串很神奇,因为它在计算机中应用很广泛,就每一个程序都需要用到字符串,所以学好字符串是非常重要的. 接下来就介绍两个字符串的基本操作 1:字符串hash  一种可以查找几个字符串有几个不同的字符串. ...

  2. Codeforces734 E. Anton and Tree

    传送门:>Here< 题意:给出一颗树,节点不是黑色就是白色,每次可以将一个颜色相同的块变颜色,问最少变几次才能让其变为同色 解题思路: 我们考虑由于每一次都是把同样颜色的色块进行变色,因 ...

  3. [CEOI2007] 树的匹配Treasury

    类型:树形 DP 传送门:>Here< 题意:给一棵树,你可以匹配有边相连的两个点,问你这棵树的最大匹配是多少,并且计算出有多少种最大匹配. 解题思路 首先树形Dp是很明显的,$f[i][ ...

  4. No more tricks, Mr Nanguo HDU - 3292(pell + 矩阵快速幂)

    No more tricks, Mr Nanguo Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Jav ...

  5. 「CodeForces 581D」Three Logos

    BUPT 2017 Summer Training (for 16) #3A 题意 给你三个矩形,需要不重叠不留空地组成一个正方形.不存在输出-1,否则输出边长和这个正方形(A,B,C表示三个不同矩形 ...

  6. FlatList

    FlatList 之前使用的组件是ListView,当时要添加一个下拉刷新,上拉加载的功能,所以对ListView做了一些封装,但是后来看官方文档,不建议再使用ListView,因为效率问题,做过An ...

  7. Hdoj 1160.FatMouse's Speed 题解

    Problem Description FatMouse believes that the fatter a mouse is, the faster it runs. To disprove th ...

  8. Android热点回顾第一期

    本文由 ImportNew - 陈强 翻译自 androidweekly.如需转载本文,请先参见文章末尾处的转载要求. Importnew注:欢迎Android爱好者参与翻译文中提及的教程,请私信联系 ...

  9. POJ 2672 Tarjan + 缩点 + 拓扑思想

    Going from u to v or from v to u? Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 17383 ...

  10. LOJ #2205. 「HNOI2014」画框 解题报告

    #2205. 「HNOI2014」画框 最小乘积生成树+KM二分图带权匹配 维护一个\((\sum A,\sum B)\)的匹配下凸包,答案在这些点中产生. 具体的,凸包两端可以直接跑单独的\(A\) ...