1,xml文件的读取
读取xml文件的方式有两种,一种是面向模型的DOM方式,一种是面向事件的SAX方式
DOM方式原理:一次性的将xml文档加入内存,在内存中形成一颗dom树,然后通过语言对树的节点进行操作。
显然这种操作查找元素快,但是一次性的将文件加载进来,要是小还行,文件大的时候会增大内存负担的,因此这种方式最好是解析小的xml文件的时候用
SAX方式原理:边读边解析,按照从做往右从上往下的顺序解析。
由于解析过的节点不能再次利用,要想使用还得再次解析,所以效率相对来说比较低,但只有事件触发了才会去读取文件,所以内存不会很大。
两种方式,各有优缺点,谁也不能代替谁,举个简单的例子吧,就像生活中的自行车无法取代汽车,汽车无法取代自行车一样,两者各有优势。根据具体需求选择。
DOM实现:
[java]
view plain
copy
print
?
- importjava.io.File;
- importjavax.xml.parsers.DocumentBuilder;
- importjavax.xml.parsers.DocumentBuilderFactory;
- importorg.w3c.dom.Document;
- importorg.w3c.dom.Node;
- publicclassdom{
- publicstaticvoidmain(Stringargs[])throwsException{
- DocumentBuilderFactorydfactory=DocumentBuilderFactory.newInstance();
- DocumentBuilderbuilder=dfactory.newDocumentBuilder();
- Documentdocument=builder.parse(newFile("test.xml"));
- Noderootn=document.getFirstChild();
- System.out.println(rootn.getNodeName());
- }
- }
SAX实现:
[java]
view plain
copy
print
?
- importjava.io.File;
- importorg.dom4j.Document;
- importorg.dom4j.Element;
- importorg.dom4j.io.SAXReader;
- publicclasssax{
- publicstaticvoidmain(Stringargs[])throwsException{
- SAXReaderreader=newSAXReader();
- Documentdocument=reader.read(newFile("test.xml"));
- Elementroote=document.getRootElement();
- Stringchilde=roote.elementText("学生");
- System.out.println(roote.getName());
- System.out.println(childe);
- }
- }
注意:需要导入dom4j的jar包,如果不使用工具需要配置classpath环境变量才能使用jar。 如果有多个学生标签,会返回第一个标签的内容。
SAX实现+xpath
[java]
view plain
copy
print
?
- packagecom.bjpowernode.xml;
- importjava.io.File;
- importorg.dom4j.Document;
- importorg.dom4j.Element;
- importorg.dom4j.io.SAXReader;
- publicclassSAXandxpath{
- publicstaticvoidmain(String[]args)throwsException{
- SAXReaderreader=newSAXReader();
- Documentdocument=reader.read(newFile("test.xml"));
- Stringxpath="/test/学生";
- Elementelement=(Element)document.selectSingleNode(xpath);
- System.out.println(element.getText());
- }
- }
使用xpath达到快速定位的效果。使用时需要导入相应的jar包
2,xml文件的写入
Dom方式:使用dom方式写入xml文件(基于dom4j)
[java]
view plain
copy
print
?
- importjava.io.FileWriter;
- importorg.dom4j.Document;
- importorg.dom4j.DocumentHelper;
- importorg.dom4j.Element;
- importorg.dom4j.io.OutputFormat;
- importorg.dom4j.io.XMLWriter;
- publicclassdomwrite{
- publicstaticvoidmain(Stringargs[])throwsException{
- Documentdocument=DocumentHelper.createDocument();
- Elementroote=document.addElement("学生信息");
- Elementchile=roote.addElement("学生");
- chile.addAttribute("id","1");
- chile.setText("shuangzhe");
- Elementchile1=roote.addElement("学生");
- chile1.addAttribute("id","2");
- chile1.setText("litongxue");
- OutputFormatformat=OutputFormat.createPrettyPrint();
- format.setEncoding("GB18030");
- XMLWriterxmlWriter=newXMLWriter(newFileWriter("student.xml"),format);
- xmlWriter.write(document);
- xmlWriter.close();
- }
- }
写入后的文件内容
[html]
view plain
copy
print
?
- <?xmlversion="1.0"encoding="GB18030"?>
- <学生信息>
- <学生id="1">shuangzhe</学生>
- <学生id="2">litongxue</学生>
- </学生信息>
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|