两种解析方式:
DOM(Document Object Model 文档对象模型)
关键字:树(Document)
优点: 把 xml 文件在内存中构造树形结构,可以遍历和修改节点
缺点: 如果文件比较大,内存有压力,解析的时间会比较长
SAX(Simple API for Xml 基于 XML 的简单 API)
关键字:流(Stream)
把 xml 文件作为输入流,触发标记开始,内容开始,标记结束等动作
优点: 解析可以立即开始,速度快,没有内存压力
缺点: 丌能对节点做修改
3) JDOM / DOM4J :目前市场上常用的 2 种解析 XML 文件的 API
dom4j-1.6.1.jar 结合了 DOM 和 SAX 两种解析方式的优点
准备:导入dom4j-1.6.1.jar 包
读取XML文件(按照文件的格式读取内容):--------------------------------------
public Static void readBook(String filename){
SAXReader reader =new SAXReader(); //解析器
File file=new File(filename); //指定xml文件
try{
Document doc =reader.read(file); //开始解析,建立树形结构并返回
Element rootElmt=doc.getRootElement(); //获得根元素:书籍列表
List list= rootElmt.elements("武侠小说"); //获得所有武侠小说的元素集合
parseNovel(list);
List list2= rootElmt.elements("computer_book"); //获得所有computer_book的元素集合
parseNovel(list2);
}catch(DocumentException e){
e.printStackTrace();
}
}
public Static void parseNovel(List list){
Iterator it =list.iterator();
while(it.hasNext()){
Element novelElmt =(Element)it.next(); ----取出元素
String bookname=novelElmt.elementText("书名"); ---读取元素的内容
String editor=novelElmt.elementText("作者");
String price=novelElmt.elementText("价格");
...
//取出元素的所有属性
List attrList= novelElmt.attributes();==Iterator attrList =novelElmt.attributeIterator();
Iterator attrIt =attrList.iterator();
while(attrIt.hasNext()){
Attribute attr = (Attribute)attrIt.next();
System.out.println(attr.getName() + "=" + attr.getValue());
}
}
}
写XML文件:-------------------------------------------------------------
常用 API 方法:
1) 给元素增加子元素: elmt.addElement( "标记名称" ) ;
2) 给元素增加属性: elmt.addAttribute( "属性名" , "属性值" ) ;
3) 给叶子元素设值: elmt.setText( "元素值" ) ;
/***************************内存中构建document文档对象***********************************/
创建一个如图的xml文件:
filename.xml:本例文件是已手动建好的空文件(可在程序中生成指定路径的空文件)
public static void builXml(String filename){
//数据源(也可是数据库查询的一个集合对象)
String[][] books ={
{"1001","武侠","天龙八部","金庸","60","1965","zh"},
{"1002","科幻","哈利波特","rowLing","86","1969","en"},
....
}
//创建一个空的文档对象
Document doc =DocumentHelper.createDocument();
//创建根元素
Element rootElmt=doc.addElement("booklist");
//增加每本书(每条数据)的元素
for(String[] book : books){
Element bookElmt = rootElmt.addElement("book");
//增加每本书的子元素(每条数据的子元素)
Element titleElmt = bookElmt.addElement("title");
Element authorElmt = bookElmt.addElement("author");
Element priceElmt = bookElmt.addElement("price");
Element yearElmt = bookElmt.addElement("year");
//给子元素添加数据
titleElmt.setText(book[2]);
authorElmt.setText(book[3]);
priceElmt .setText(book[4]);
yearElmt .setText(book[5]);
//给book元素增加两个属性:isbn="1001" calalog="武侠"
bookElmt.addAttribute("isbn",book[0]);
bookElmt.addAttribute("calalog",book[1]);
//给title元素增加一个属性:lang="zh"
titleElmt.addAttribute("lang",book[6]);
}
outputXml(doc,filename);
}
/*********************输出document文档对象到指定位置的xml文件****************************************/
private static void outputXml(Document coc ,String filename){
try{
//创建一个java.io包中的FileWriter对象,指定要生成的目标文件
FileWriter fw = new FileWriter(filename);
//指定xml文件的输出格式
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("utf-8");
//写xml文件到操作系统
XMLWriter xmlWriter = new XMLWriter(fw , format);
xmlWriter.write(doc);
xmlWriter.close();
}catch(IOException e){
e.printStackTrace();
}
}
XML文件中搜索某个节点的值(按照文件的格式读取内容):--------------
1) XPath:在 XML 文件中查找或定位信息的语言:XPath 可以通过元素/属性/值来定位或导航
2) 节点(Node): 相当于 XML 文件中的元素
3) 指定条件定位元素的方式
一:读取xml文件的所有元素
public Static void readBook(String filename){
SAXReader reader =new SAXReader(); //解析器
File file=new File(filename); //指定xml文件
try{
Document doc =reader.read(file); //开始解析,建立树形结构并返回
//Element rootElmt=doc.getRootElement(); //获得根元素:书籍列表
//List list= rootElmt.elements("武侠小说"); //获得所有武侠小说的元素集合
Node root = doc.selectSingleNode("/booklist");//取根节点(根元素),绝对路径:/booklist,相对路径:book
//查所有元素
List<Element> list = root.selectNodes("book");
for(Element e : list){
String title =e.elementText("title")---e元素的子元素title元素的内容
String zh =e.element("title").attributeValue("lang");---e元素的子元素title元素的属性
String isbn=e.attributeValue("isbn");---e元素的属性
}
//查询指定的元素
//查找所有中文书:lang=zh是title的属性(list中存放的都是title元素,book/title:相对路径,[@lang='zh']:过滤条件)
List<Element> list = root.selectNodes("book/title[@lang='zh'] ");
//查询所有武侠类书:book元素属性:catalog="武侠",list里的元素是book元素
List<Element> list = root.selectNodes("book[@catalog='武侠'] ");
//查询价格大于80的书:price是book的子元素,list里的每个元素是book元素
List<Element> list = root.selectNodes("book[price > 80] ");
//查询作者是金庸的书或古龙的书
List<Element> list = root.selectNodes("book[author='金庸' or author='古龙'] ");
//查询英文价格大于80的书
List<Element> list = root.selectNodes("book[price > 80 and title[@lang='en']] ");
for(Element e : list){
e.getStringValue();
}
}catch(DocumentException e){
e.printStackTrace();
}
}
相关推荐
在IT领域,C#是一种广泛使用的编程语言,尤其在开发Windows桌面应用、Web应用以及游戏等方面。本项目涉及的核心技术是“读取XML文件”和“写入Excel表格”。XML(Extensible Markup Language)是一种用于存储和传输...
1. SpringBoot简介:SpringBoot简化了Spring应用的初始搭建以及开发过程,通过内嵌的Tomcat服务器,使得我们可以快速启动Web服务。它还包含了对MVC、数据访问、安全等核心功能的支持,方便开发者构建高性能的Web应用...
总结来说,这个实例涵盖了ASP.NET中处理XML文件和数据库的基本操作,包括读取XML、写入数据库、从数据库检索数据以及更新XML。这些技能对于开发任何涉及数据存储和交换的ASP.NET应用程序都是至关重要的。通过熟练...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。DOM4J是Java中一个非常优秀的XML处理库,它提供了丰富的API,使得操作XML文件变得简单而高效...
XML(eXtensible Markup Language)是一种用于存储和交换数据的标记语言,广泛应用于软件开发、数据存储和网络通信等领域。Matlab作为一个强大的数值计算和数据分析环境,也提供了与XML交互的功能,这主要通过XML ...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。在Java中,处理XML文件主要有四种方式:DOM(Document Object Model)、SAX(Simple API for...
**XML写入操作** 使用Java的DOM API写入XML,可以分为以下步骤: 1. 创建`DocumentBuilderFactory`实例。 2. 使用工厂创建`DocumentBuilder`。 3. 通过`DocumentBuilder`创建一个空的`Document`对象。 4. 创建所需...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。MFC(Microsoft Foundation Classes)是微软提供的一个C++库,用于构建Windows应用程序。在...
在IT行业中,XML(eXtensible Markup Language)是一种用于存储和传输数据的标准化格式,广泛应用在各种领域,如Web服务、配置文件、数据交换等。C++作为一门强大的编程语言,提供了多种库来处理XML文件,其中之一...
总结来说,本示例展示了如何利用C语言的xml2库读取和解析XML文件,特别是针对Servlet应用的web.xml配置文件。理解并掌握这些知识对于进行XML相关的C编程至关重要,它能帮助开发者有效地处理各种结构化的数据存储和...
了解并熟练使用这些API,对于Java开发者来说至关重要,因为它们可以帮助我们有效地读取、写入、验证和处理XML数据。在处理XML问题时,熟悉这些基本概念和API可以帮助快速定位和解决问题,提高开发效率。
总结起来,XML Web服务开发涉及了从基础XML语法到高级的分布式系统概念,如.NET Remoting和服务描述。开发者需要理解和掌握XML的结构和语法规则,以及如何在.NET环境中使用XML进行数据处理和Web服务的构建。同时,...
总的来说,理解并熟练掌握这些ASP.NET中的XML处理类,对于开发高效、灵活的Web应用程序至关重要。无论是从XML文件中提取数据,还是向XML文件写入数据,都有相应的最佳实践和策略可供选择。通过不断实践和学习,...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标准格式,特别是在软件开发和Web应用程序中广泛应用。然而,XML文件在处理中文字符时经常会出现乱码问题,这主要是由于编码不一致或编码声明错误导致...
4. JSP和XML的整合:如何在JSP页面中读取和写入XML数据,以及使用XPath和XSLT处理XML数据。 5. Ajax技术:如何使用XMLHttpRequest对象进行异步请求,以及XML数据在Ajax中的应用。 6. 安全和性能优化:讨论如何避免...
StAX则提供了一种流式处理XML的方式,允许开发者按需读取或写入XML元素,更高效且节省内存。 在xml-apis-2.0.2.jar 包中,"org"目录可能包含了与XML处理相关的组织结构包,比如解析器实现和相关接口。"META-INF...
例如,用户上传XML文件,服务器端的C#代码读取文件,处理数据,然后写入数据库,或者返回修改后的XML结果。为了提高性能和安全性,应该始终确保正确处理XML解析错误,并防止XML注入攻击。 在提供的压缩包文件中,...
XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,它以其结构化、自解释性和可扩展性而被广泛应用于Web开发中。本教程将深入讲解如何利用XML将数据写入网页,从而减轻数据库的负担,提高网站...
XML文件可以直接被程序读取和写入,无需中间数据库系统。 3. 配置文件:许多应用程序和框架使用XML作为配置文件,因为它提供了清晰的结构和易于理解的语法。 4. 文档表示:XML也被用于创建结构化的电子文档,如SVG...
在现代Web应用开发中,数据库性能往往是制约应用性能的关键因素之一。为了提高数据库系统的整体性能,一种常见的做法是实施读写分离策略。本文将详细介绍如何构建一个高性能的Web应用,并通过MySQL的读写分离来实现...