一、基本介绍
xml(可扩展标记语言,extensible markup language)是一种用于存储和传输数据的标记语言,由w3c(万维网联盟)于1998年发布。xml的设计目的是提供一种简单、可扩展且自描述的数据格式,使得数据可以在不同的系统和应用程序之间轻松传输和共享。
二、基本特征
1、可扩展性:
xml允许用户定义自己的标记(标签),因此可以根据需要灵活地表示各种数据类型,而不是依赖于预定义的标记。
2、自描述性:
xml文档本身包含了数据及其结构的信息,使得人类和机器都能理解数据的含义。
3、结构化:
xml文档通过层级结构(树结构)来组织数据,具有父子关系,便于表示复杂的数据结构。
4、跨平台:
xml是一种文本格式,可以在不同的系统和应用程序之间轻松传输和共享数据。
5、兼容性:
xml与许多其他技术兼容,包括html、xslt、json等,广泛应用于web服务、数据交换等领域。
三、基本操作
1. 读取xml文件
使用documentbuilderfactory和documentbuilder读取xml文件:
import javax.xml.parsers.documentbuilder;
import javax.xml.parsers.documentbuilderfactory;
import org.w3c.dom.document;
import org.w3c.dom.node;
import org.w3c.dom.nodelist;
import java.io.file;
public class xmlreader {
public static void main(string[] args) throws exception {
file xmlfile = new file("path/to/your/file.xml");
documentbuilderfactory dbfactory = documentbuilderfactory.newinstance();
documentbuilder dbuilder = dbfactory.newdocumentbuilder();
document doc = dbuilder.parse(xmlfile);
// 获取根节点
doc.getdocumentelement().normalize();
system.out.println("root element :" + doc.getdocumentelement().getnodename());
// 遍历节点
nodelist nlist = doc.getelementsbytagname("*");
for (int temp = 0; temp < nlist.getlength(); temp++) {
node nnode = nlist.item(temp);
system.out.println("\nnode #" + temp + " [" + nnode.getnodename() + "]:");
if (nnode.getnodetype() == node.text_node) {
string nodevalue = nnode.getnodevalue().trim();
if (nodevalue.length() > 0) {
system.out.println("node value: " + nodevalue);
}
}
}
}
}2. 创建xml文件
使用documentbuilderfactory创建xml文件:
import javax.xml.parsers.documentbuilder;
import javax.xml.parsers.documentbuilderfactory;
import org.w3c.dom.document;
import org.w3c.dom.element;
public class xmlwriter {
public static void main(string[] args) throws exception {
documentbuilderfactory dbfactory = documentbuilderfactory.newinstance();
documentbuilder dbuilder = dbfactory.newdocumentbuilder();
document doc = dbuilder.newdocument();
// 创建根元素
element rootelement = doc.createelement("root");
doc.appendchild(rootelement);
// 创建子元素
element childelement = doc.createelement("child");
childelement.appendchild(doc.createtextnode("value"));
rootelement.appendchild(childelement);
// 保存到文件
transformerfactory transformerfactory = transformerfactory.newinstance();
transformer transformer = transformerfactory.newtransformer();
transformer.setoutputproperty(outputkeys.indent, "yes");
transformer.transform(new domsource(doc), new streamresult(new file("path/to/your/newfile.xml")));
}
}3. 修改xml文件
修改xml文件中的元素:
import javax.xml.parsers.documentbuilder;
import javax.xml.parsers.documentbuilderfactory;
import org.w3c.dom.document;
import org.w3c.dom.element;
import org.w3c.dom.node;
import org.w3c.dom.nodelist;
import javax.xml.transform.transformer;
import javax.xml.transform.transformerfactory;
import javax.xml.transform.dom.domsource;
import javax.xml.transform.stream.streamresult;
import java.io.file;
public class xmlmodifier {
public static void main(string[] args) throws exception {
file xmlfile = new file("path/to/your/modifiedfile.xml");
documentbuilderfactory dbfactory = documentbuilderfactory.newinstance();
documentbuilder dbuilder = dbfactory.newdocumentbuilder();
document doc = dbuilder.parse(xmlfile);
// 修改元素值
nodelist nlist = doc.getelementsbytagname("child");
for (int temp = 0; temp < nlist.getlength(); temp++) {
node nnode = nlist.item(temp);
if (nnode.getnodetype() == node.element_node) {
element eelement = (element) nnode;
eelement.settextcontent("new value");
}
}
// 添加新元素
element newchild = doc.createelement("newchild");
newchild.appendchild(doc.createtextnode("new value"));
doc.getdocumentelement().appendchild(newchild);
// 删除元素
nlist = doc.getelementsbytagname("child");
if (nlist.getlength() > 1) {
node removenode = nlist.item(0);
removenode.getparentnode().removechild(removenode);
}
// 保存修改
transformerfactory transformerfactory = transformerfactory.newinstance();
transformer transformer = transformerfactory.newtransformer();
transformer.setoutputproperty(outputkeys.indent, "yes");
transformer.transform(new domsource(doc), new streamresult(new file("path/to/your/modifiedfile.xml")));
}
}4. 使用xpath查询xml
import javax.xml.parsers.documentbuilder;
import javax.xml.parsers.documentbuilderfactory;
import org.w3c.dom.document;
import org.w3c.dom.nodelist;
import javax.xml.xpath.xpath;
import javax.xml.xpath.xpathconstants;
import javax.xml.xpath.xpathfactory;
import java.io.file;
public class xpathexample {
public static void main(string[] args) throws exception {
file xmlfile = new file("path/to/your/file.xml");
documentbuilderfactory dbfactory = documentbuilderfactory.newinstance();
documentbuilder dbuilder = dbfactory.newdocumentbuilder();
document doc = dbuilder.parse(xmlfile);
xpathfactory xpf = xpathfactory.newinstance();
xpath xpath = xpf.newxpath();
nodelist nodelist = (nodelist) xpath.evaluate("//child", doc, xpathconstants.nodeset);
for (int i = 0; i < nodelist.getlength(); i++) {
system.out.println(nodelist.item(i).gettextcontent());
}
}
}五、注意事项
确保在项目中引入了必要的库和依赖。
处理xml时,考虑到xml的格式和结构,确保代码能够正确地访问和修改xml元素。
在修改xml文件后,记得保存更改。
异常处理是处理xml文件时非常重要的一部分,确保你的代码能够妥善处理可能出现的异常情况。
到此这篇关于浅析java中的xml文件处理的文章就介绍到这了,更多相关java xml文件处理内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论