• 97足球博彩 2018-06-24
  • 这家上市公司存巨大黑幕!六大部门同时出手 2018-06-24
  • 狗年生肖特种邮票今日在川首发 2018-06-24
  • 长株潭城铁长沙站以西段通过安全评估 月底通车运营 2018-06-24
  • 《寻梦环游记》《至爱梵高》 明年奥斯卡种子选手且看且珍惜 2018-06-23
  • 海南特区改革开放30年:闯出一片辽阔的海 2018-06-23
  • 黑龙江省近三年有400多名责任人因破坏营商环境被处理 2018-06-23
  • 右玉:锣鼓喧天庆盛世 万民欢腾闹元宵 2018-06-23
  • 【手绘H5】我们的领袖习近平 2018-06-23
  • 上市公司并购新三板企业升温 2018-06-23
  • 特朗普再与世界"为敌" 多国斥其关于耶路撒冷决定 2018-06-22
  • 严防“两节”期间“四风”反弹 持续保持高压态势 2018-06-22
  • 反转!华南理工大学否认向莱阳14岁神童发送考察函 2018-06-21
  • 中国出版集团公司总裁谭跃委员:唱响新时代的好声音 2018-06-21
  • 新華網評:分享經濟,別演成分享的“獨角戲” 2018-06-20
  • 【ruby教程】Ruby XML, XSLT 和 XPath 教程

    栏目: Ruby 发布于: 2014-11-26 08:06:50

    Ruby XML, XSLT 和 XPath 教程


    什么是 XML ?

    XML 指可扩展标记语言(eXtensible Markup Language)。

    可扩展标记语言,标准通用标记语言的子集,一种用于标记电子文件使其具有结构性的标记语言。

    它可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 它非常适合万维网传输,提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。

    更多内容请查看我们的 XML 教程


    XML解析器结构和API

    XML的解析器主要有DOM和SAX两种。

    • SAX解析器是基于事件处理的,需要从头到尾把XML文档扫描一遍,在扫描的过程中,每次遇到一个语法结构时,就会调用这个特定语法结构的事件处理程序,向应用程序发送一个事件。
    • DOM是文档对象模型解析,构建文档的分层语法结构,在内存中建立DOM树,DOM树的节点以对象的形式来标识,文档解析文成以后,文档的整个DOM树都会放在内存中。

    Ruby 中解析及创建 XML

    RUBY中对XML的文档的解析可以使用这个库REXML库。

    REXML库是ruby的一个XML工具包,是使用纯Ruby语言编写的,遵守XML1.0规范。

    在Ruby1.8版本及其以后,RUBY标准库中将包含REXML。

    REXML库的路径是: rexml/document

    所有的方法和类都被封装到一个REXML??槟?。

    REXML解析器比其他的解析器有以下优点:

    • 100% 由 Ruby 编写。
    • 可适用于 SAX 和 DOM 解析器。
    • 它是轻量级的,不到2000行代码。
    • 很容易理解的方法和类。
    • 基于 SAX2 API 和完整的 XPath 支持。
    • 使用 Ruby 安装,而无需单独安装。

    以下为实例的 XML 代码,保存为movies.xml:

    <collection shelf="New Arrivals">
    <movie title="Enemy Behind">
       <type>War, Thriller</type>
       <format>DVD</format>
       <year>2003</year>
       <rating>PG</rating>
       <stars>10</stars>
       <description>Talk about a US-Japan war</description>
    </movie>
    <movie title="Transformers">
       <type>Anime, Science Fiction</type>
       <format>DVD</format>
       <year>1989</year>
       <rating>R</rating>
       <stars>8</stars>
       <description>A schientific fiction</description>
    </movie>
       <movie title="Trigun">
       <type>Anime, Action</type>
       <format>DVD</format>
       <episodes>4</episodes>
       <rating>PG</rating>
       <stars>10</stars>
       <description>Vash the Stampede!</description>
    </movie>
    <movie title="Ishtar">
       <type>Comedy</type>
       <format>VHS</format>
       <rating>PG</rating>
       <stars>2</stars>
       <description>Viewable boredom</description>
    </movie>
    </collection>
    

    DOM 解析器

    让我们先来解析 XML 数据,首先我们先引入 rexml/document 库,通常我们可以将 REXML 在顶级的命名空间中引入:

    #!/usr/bin/ruby -w
    
    require 'rexml/document'
    include REXML
    
    xmlfile = File.new("movies.xml")
    xmldoc = Document.new(xmlfile)
    
    # 获取 root 元素
    root = xmldoc.root
    puts "Root element : " + root.attributes["shelf"]
    
    # 以下将输出电影标题
    xmldoc.elements.each("collection/movie"){ 
       |e| puts "Movie Title : " + e.attributes["title"] 
    }
    
    # 以下将输出所有电影类型
    xmldoc.elements.each("collection/movie/type") {
       |e| puts "Movie Type : " + e.text 
    }
    
    # 以下将输出所有电影描述
    xmldoc.elements.each("collection/movie/description") {
       |e| puts "Movie Description : " + e.text 
    }
    

    以上实例输出结果为:

    Root element : New Arrivals
    Movie Title : Enemy Behind
    Movie Title : Transformers
    Movie Title : Trigun
    Movie Title : Ishtar
    Movie Type : War, Thriller
    Movie Type : Anime, Science Fiction
    Movie Type : Anime, Action
    Movie Type : Comedy
    Movie Description : Talk about a US-Japan war
    Movie Description : A schientific fiction
    Movie Description : Vash the Stampede!
    Movie Description : Viewable boredom
    SAX-like Parsing:
    

    SAX 解析器

    处理相同的数据文件:movies.xml,不建议SAX的解析为一个小文件,以下是个简单的实例:

    #!/usr/bin/ruby -w
    
    require 'rexml/document'
    require 'rexml/streamlistener'
    include REXML
    
    
    class MyListener
      include REXML::StreamListener
      def tag_start(*args)
        puts "tag_start: #{args.map {|x| x.inspect}.join(', ')}"
      end
    
      def text(data)
        return if data =~ /^\w*$/     # whitespace only
        abbrev = data[0..40] + (data.length > 40 ? "..." : "")
        puts "  text   :   #{abbrev.inspect}"
      end
    end
    
    list = MyListener.new
    xmlfile = File.new("movies.xml")
    Document.parse_stream(xmlfile, list)
    

    以上输出结果为:

    tag_start: "collection", {"shelf"=>"New Arrivals"}
    tag_start: "movie", {"title"=>"Enemy Behind"}
    tag_start: "type", {}
      text   :   "War, Thriller"
    tag_start: "format", {}
    tag_start: "year", {}
    tag_start: "rating", {}
    tag_start: "stars", {}
    tag_start: "description", {}
      text   :   "Talk about a US-Japan war"
    tag_start: "movie", {"title"=>"Transformers"}
    tag_start: "type", {}
      text   :   "Anime, Science Fiction"
    tag_start: "format", {}
    tag_start: "year", {}
    tag_start: "rating", {}
    tag_start: "stars", {}
    tag_start: "description", {}
      text   :   "A schientific fiction"
    tag_start: "movie", {"title"=>"Trigun"}
    tag_start: "type", {}
      text   :   "Anime, Action"
    tag_start: "format", {}
    tag_start: "episodes", {}
    tag_start: "rating", {}
    tag_start: "stars", {}
    tag_start: "description", {}
      text   :   "Vash the Stampede!"
    tag_start: "movie", {"title"=>"Ishtar"}
    tag_start: "type", {}
    tag_start: "format", {}
    tag_start: "rating", {}
    tag_start: "stars", {}
    tag_start: "description", {}
      text   :   "Viewable boredom"
    

    XPath 和 Ruby

    我们可以使用XPath来查看XML ,XPath 是一门在 XML 文档中查找信息的语言(查看:XPath 教程)。

    XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言。XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。

    Ruby 通过 REXML 的 XPath 类支持 XPath,它是基于树的分析(文档对象模型)。

    #!/usr/bin/ruby -w
    
    require 'rexml/document'
    include REXML
    
    xmlfile = File.new("movies.xml")
    xmldoc = Document.new(xmlfile)
    
    # 第一个电影的信息
    movie = XPath.first(xmldoc, "http://movie")
    p movie
    
    # 打印所有电影类型
    XPath.each(xmldoc, "http://type") { |e| puts e.text }
    
    # 获取所有电影格式的类型,返回数组
    names = XPath.match(xmldoc, "http://format").map {|x| x.text }
    p names
    

    以上实例输出结果为:

    <movie title='Enemy Behind'> ... </>
    War, Thriller
    Anime, Science Fiction
    Anime, Action
    Comedy
    ["DVD", "DVD", "DVD", "VHS"]
    

    XSLT 和 Ruby

    Ruby 中有两个 XSLT 解析器,以下给出简要描述:

    Ruby-Sablotron

    这个解析器是由正义Masayoshi Takahash编写和维护。这主要是为Linux操作系统编写的,需要以下库:

    • Sablot
    • Iconv
    • Expat

    你可以在 Ruby-Sablotron 找到这些库。

    XSLT4R

    XSLT4R 由 Michael Neumann 编写。 XSLT4R 用于简单的命令行交互,可以被第三方应用程序用来转换XML文档。

    XSLT4R需要XMLScan操作,包含了 XSLT4R 归档,它是一个100%的Ruby的???。这些??榭梢允褂帽曜嫉腞uby安装方法(即Ruby install.rb)进行安装。

    XSLT4R 语法格式如下:

    ruby xslt.rb stylesheet.xsl document.xml [arguments]
    

    如果您想在应用程序中使用XSLT4R,您可以引入XSLT及输入你所需要的参数。实例如下:

    require "xslt"
    
    stylesheet = File.readlines("stylesheet.xsl").to_s
    xml_doc = File.readlines("document.xml").to_s
    arguments = { 'image_dir' => '/....' }
    
    sheet = XSLT::Stylesheet.new( stylesheet, arguments )
    
    # output to StdOut
    sheet.apply( xml_doc )
    
    # output to 'str'
    str = ""
    sheet.output = [ str ]
    sheet.apply( xml_doc )
    

    更多资料


    本文转载自:w3cschool
    本站文章除注明转载外,均为本站原创或编译?;队魏涡问降淖?,但请务必注明出处。
    转载请注明:文章转载自 七星彩票平台
    本文标题:【ruby教程】Ruby XML, XSLT 和 XPath 教程
    IT技术书籍推荐:
    Python学习手册(第4版)
    Python学习手册(第4版)
    鲁特兹 (Mark Lutz) (作者), 李军 (译者), 刘红伟 (译者), 等 (译者)
    《Python学习手册(第4版)》内容简介:学习Python的主要内建对象类型:数字、列表和字典。使用Python语句创建和处理对象,并且学习Python的通用语法模型。使用函数构造和重用代码,函数是Python的基本过程工具。学习Python??椋悍庾坝锞?、函数以及其他工具,以便构建较大的组件。学习Python的面向对象编程工具,用于组织程序代码。学习异常处理模型,以及用于编写较大程序的开发工具。了解高级Python工具,如装饰器、描述器、元类和Unicode处理等。