`
2277259257
  • 浏览: 515262 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

web开发总结----xml的写入、读取---1

 
阅读更多

两种解析方式:
  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();

   }

 

}

 

  • 大小: 66.4 KB
  • 大小: 68.1 KB
分享到:
评论

相关推荐

    C# 读取XML文件并写入Excel表格

    在IT领域,C#是一种广泛使用的编程语言,尤其在开发Windows桌面应用、Web应用以及游戏等方面。本项目涉及的核心技术是“读取XML文件”和“写入Excel表格”。XML(Extensible Markup Language)是一种用于存储和传输...

    web-uploader-master.zip

    1. SpringBoot简介:SpringBoot简化了Spring应用的初始搭建以及开发过程,通过内嵌的Tomcat服务器,使得我们可以快速启动Web服务。它还包含了对MVC、数据访问、安全等核心功能的支持,方便开发者构建高性能的Web应用...

    asp.net 读取XML文件中的数据和写入数据库实例

    总结来说,这个实例涵盖了ASP.NET中处理XML文件和数据库的基本操作,包括读取XML、写入数据库、从数据库检索数据以及更新XML。这些技能对于开发任何涉及数据存储和交换的ASP.NET应用程序都是至关重要的。通过熟练...

    利用dom4j--读取xml文件

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。DOM4J是Java中一个非常优秀的XML处理库,它提供了丰富的API,使得操作XML文件变得简单而高效...

    matlab读取XML,XML转换为matlab

    XML(eXtensible Markup Language)是一种用于存储和交换数据的标记语言,广泛应用于软件开发、数据存储和网络通信等领域。Matlab作为一个强大的数值计算和数据分析环境,也提供了与XML交互的功能,这主要通过XML ...

    java读取和写入xml文件

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。在Java中,处理XML文件主要有四种方式:DOM(Document Object Model)、SAX(Simple API for...

    xml写入读取例子

    **XML写入操作** 使用Java的DOM API写入XML,可以分为以下步骤: 1. 创建`DocumentBuilderFactory`实例。 2. 使用工厂创建`DocumentBuilder`。 3. 通过`DocumentBuilder`创建一个空的`Document`对象。 4. 创建所需...

    xml读取工具,用于MFC的XML文件的读取

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,广泛应用于软件开发、Web服务和数据交换等领域。MFC(Microsoft Foundation Classes)是微软提供的一个C++库,用于构建Windows应用程序。在...

    C++读取XML文件

    在IT行业中,XML(eXtensible Markup Language)是一种用于存储和传输数据的标准化格式,广泛应用在各种领域,如Web服务、配置文件、数据交换等。C++作为一门强大的编程语言,提供了多种库来处理XML文件,其中之一...

    读取xml文件示例

    总结来说,本示例展示了如何利用C语言的xml2库读取和解析XML文件,特别是针对Servlet应用的web.xml配置文件。理解并掌握这些知识对于进行XML相关的C编程至关重要,它能帮助开发者有效地处理各种结构化的数据存储和...

    xml-apis-1.4.01.jar.zip

    了解并熟练使用这些API,对于Java开发者来说至关重要,因为它们可以帮助我们有效地读取、写入、验证和处理XML数据。在处理XML问题时,熟悉这些基本概念和API可以帮助快速定位和解决问题,提高开发效率。

    XML WEB Service开发

    总结起来,XML Web服务开发涉及了从基础XML语法到高级的分布式系统概念,如.NET Remoting和服务描述。开发者需要理解和掌握XML的结构和语法规则,以及如何在.NET环境中使用XML进行数据处理和Web服务的构建。同时,...

    ASP.NET读取XML文件

    总的来说,理解并熟练掌握这些ASP.NET中的XML处理类,对于开发高效、灵活的Web应用程序至关重要。无论是从XML文件中提取数据,还是向XML文件写入数据,都有相应的最佳实践和策略可供选择。通过不断实践和学习,...

    解决读取XML元素时的中文乱码的程序

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标准格式,特别是在软件开发和Web应用程序中广泛应用。然而,XML文件在处理中文字符时经常会出现乱码问题,这主要是由于编码不一致或编码声明错误导致...

    动态Web数据库技术——基于JSP和XML技术实现

    4. JSP和XML的整合:如何在JSP页面中读取和写入XML数据,以及使用XPath和XSLT处理XML数据。 5. Ajax技术:如何使用XMLHttpRequest对象进行异步请求,以及XML数据在Ajax中的应用。 6. 安全和性能优化:讨论如何避免...

    xml-apis-2.0.2.jar ecside 依赖包之一

    StAX则提供了一种流式处理XML的方式,允许开发者按需读取或写入XML元素,更高效且节省内存。 在xml-apis-2.0.2.jar 包中,"org"目录可能包含了与XML处理相关的组织结构包,比如解析器实现和相关接口。"META-INF...

    C#操作XMl 三种方法 包括对读取入库

    例如,用户上传XML文件,服务器端的C#代码读取文件,处理数据,然后写入数据库,或者返回修改后的XML结果。为了提高性能和安全性,应该始终确保正确处理XML解析错误,并防止XML注入攻击。 在提供的压缩包文件中,...

    讲XML中的数据写入网页实例

    XML(eXtensible Markup Language)是一种用于存储和传输数据的标记语言,它以其结构化、自解释性和可扩展性而被广泛应用于Web开发中。本教程将深入讲解如何利用XML将数据写入网页,从而减轻数据库的负担,提高网站...

    网站开发新动力用XML轻松开发Web网站(PDG)

    XML文件可以直接被程序读取和写入,无需中间数据库系统。 3. 配置文件:许多应用程序和框架使用XML作为配置文件,因为它提供了清晰的结构和易于理解的语法。 4. 文档表示:XML也被用于创建结构化的电子文档,如SVG...

    构建高性能web之路------mysql读写分离实战.pdf

    在现代Web应用开发中,数据库性能往往是制约应用性能的关键因素之一。为了提高数据库系统的整体性能,一种常见的做法是实施读写分离策略。本文将详细介绍如何构建一个高性能的Web应用,并通过MySQL的读写分离来实现...

Global site tag (gtag.js) - Google Analytics