在Ruby中處理XML和XSLT以及XPath的簡單教程_ruby專題

來源:互聯網
上載者:User

什麼是 XML ?

XML 指可延伸標記語言 (XML)(eXtensible Markup Language)。

可延伸標記語言 (XML),標準通用標記語言 (SGML)的子集,一種用於標記電子檔案使其具有結構性的標記語言。

它可以用來標記資料、定義資料類型,是一種允許使用者對自己的標記語言進行定義的源語言。 它非常適合全球資訊網傳輸,提供統一的方法來描述和交換獨立於應用程式或供應商的結構化資料。

XML解析器結構和API

XML的解析器主要有DOM和SAX兩種。

  1.     SAX解析器是基於事件處理的,需要從頭到尾把XML文檔掃描一遍,在掃描的過程中,每次遇到一個文法結構時,就會調用這個特定文法結構的事件處理常式,嚮應用程式發送一個事件。
  2.     DOM是文件物件模型解析,構建文檔的分層文法結構,在記憶體中建立DOM樹,DOM樹的節點以對象的形式來標識,文檔解析文成以後,文檔的整個DOM樹都會放在記憶體中。

Ruby 中解析及建立 XML

RUBY中對XML的文檔的解析可以使用這個庫REXML庫。

REXML庫是ruby的一個XML工具包,是使用純Ruby語言編寫的,遵守XML1.0規範。

在Ruby1.8版本及其以後,RUBY標準庫中將包含REXML。

REXML庫的路徑是: rexml/document

所有的方法和類都被封裝到一個REXML模組內。

REXML解析器比其他的解析器有以下優點:

  1.     100% 由 Ruby 編寫。
  2.     可適用於 SAX 和 DOM 解析器。
  3.     它是輕量級的,不到2000行代碼。
  4.     很容易理解的方法和類。
  5.     基於 SAX2 API 和完整的 XPath 支援。
  6.     使用 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.rootputs "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 ArrivalsMovie Title : Enemy BehindMovie Title : TransformersMovie Title : TrigunMovie Title : IshtarMovie Type : War, ThrillerMovie Type : Anime, Science FictionMovie Type : Anime, ActionMovie Type : ComedyMovie Description : Talk about a US-Japan warMovie Description : A schientific fictionMovie Description : Vash the Stampede!Movie Description : Viewable boredomSAX-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}" endend list = MyListener.newxmlfile = 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(標準通用標記語言 (SGML)的子集)文檔中某部分位置的語言。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, "//movie")p movie # 列印所有電影類型XPath.each(xmldoc, "//type") { |e| puts e.text } # 擷取所有電影格式的類型,返回數組names = XPath.match(xmldoc, "//format").map {|x| x.text }p names

以上執行個體輸出結果為:

<movie title='Enemy Behind'> ... </>War, ThrillerAnime, Science FictionAnime, ActionComedy["DVD", "DVD", "DVD", "VHS"]

XSLT 和 Ruby

Ruby 中有兩個 XSLT 解析器,以下給出簡要描述:
Ruby-Sablotron

這個解析器是由正義Masayoshi Takahash編寫和維護。這主要是為Linux作業系統編寫的,需要以下庫:

  1.     Sablot
  2.     Iconv
  3.     Expat

你可以在 Ruby-Sablotron 找到這些庫。
XSLT4R
XSLT4R 由 Michael Neumann 編寫。 XSLT4R 用於簡單的命令列互動,可以被第三方應用程式用來轉換XML文檔。

XSLT4R需要XMLScan操作,包含了 XSLT4R 歸檔,它是一個100%的Ruby的模組。這些模組可以使用標準的Ruby安裝方法(即Ruby install.rb)進行安裝。

XSLT4R 文法格式如下:

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

如果您想在應用程式中使用XSLT4R,您可以引入XSLT及輸入你所需要的參數。執行個體如下:

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.