欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Ruby中處理XML和XSLT以及XPath的簡(jiǎn)單教程

 更新時(shí)間:2015年04月10日 08:54:02   投稿:goldensun  
這篇文章主要介紹了在Ruby中處理XML和XSLT以及XPath的簡(jiǎn)單教程,對(duì)Ruby on Rails的學(xué)習(xí)上手有一定的幫助,需要的朋友可以參考下

什么是 XML ?

XML 指可擴(kuò)展標(biāo)記語(yǔ)言(eXtensible Markup Language)。

可擴(kuò)展標(biāo)記語(yǔ)言,標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言的子集,一種用于標(biāo)記電子文件使其具有結(jié)構(gòu)性的標(biāo)記語(yǔ)言。

它可以用來(lái)標(biāo)記數(shù)據(jù)、定義數(shù)據(jù)類型,是一種允許用戶對(duì)自己的標(biāo)記語(yǔ)言進(jìn)行定義的源語(yǔ)言。 它非常適合萬(wàn)維網(wǎng)傳輸,提供統(tǒng)一的方法來(lái)描述和交換獨(dú)立于應(yīng)用程序或供應(yīng)商的結(jié)構(gòu)化數(shù)據(jù)。

XML解析器結(jié)構(gòu)和API

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

  1.     SAX解析器是基于事件處理的,需要從頭到尾把XML文檔掃描一遍,在掃描的過(guò)程中,每次遇到一個(gè)語(yǔ)法結(jié)構(gòu)時(shí),就會(huì)調(diào)用這個(gè)特定語(yǔ)法結(jié)構(gòu)的事件處理程序,向應(yīng)用程序發(fā)送一個(gè)事件。
  2.     DOM是文檔對(duì)象模型解析,構(gòu)建文檔的分層語(yǔ)法結(jié)構(gòu),在內(nèi)存中建立DOM樹,DOM樹的節(jié)點(diǎn)以對(duì)象的形式來(lái)標(biāo)識(shí),文檔解析文成以后,文檔的整個(gè)DOM樹都會(huì)放在內(nèi)存中。

Ruby 中解析及創(chuàng)建 XML

RUBY中對(duì)XML的文檔的解析可以使用這個(gè)庫(kù)REXML庫(kù)。

REXML庫(kù)是ruby的一個(gè)XML工具包,是使用純Ruby語(yǔ)言編寫的,遵守XML1.0規(guī)范。

在Ruby1.8版本及其以后,RUBY標(biāo)準(zhǔn)庫(kù)中將包含REXML。

REXML庫(kù)的路徑是: rexml/document

所有的方法和類都被封裝到一個(gè)REXML模塊內(nèi)。

REXML解析器比其他的解析器有以下優(yōu)點(diǎn):

  1.     100% 由 Ruby 編寫。
  2.     可適用于 SAX 和 DOM 解析器。
  3.     它是輕量級(jí)的,不到2000行代碼。
  4.     很容易理解的方法和類。
  5.     基于 SAX2 API 和完整的 XPath 支持。
  6.     使用 Ruby 安裝,而無(wú)需單獨(dú)安裝。

以下為實(shí)例的 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 解析器

讓我們先來(lái)解析 XML 數(shù)據(jù),首先我們先引入 rexml/document 庫(kù),通常我們可以將 REXML 在頂級(jí)的命名空間中引入:

#!/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"]
 
# 以下將輸出電影標(biāo)題
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
}

以上實(shí)例輸出結(jié)果為:

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 解析器

處理相同的數(shù)據(jù)文件:movies.xml,不建議SAX的解析為一個(gè)小文件,以下是個(gè)簡(jiǎn)單的實(shí)例:

#!/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)

以上輸出結(jié)果為:

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來(lái)查看XML ,XPath 是一門在 XML 文檔中查找信息的語(yǔ)言(查看:XPath 教程)。

XPath即為XML路徑語(yǔ)言,它是一種用來(lái)確定XML(標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言的子集)文檔中某部分位置的語(yǔ)言。XPath基于XML的樹狀結(jié)構(gòu),提供在數(shù)據(jù)結(jié)構(gòu)樹中找尋節(jié)點(diǎn)的能力。

Ruby 通過(guò) REXML 的 XPath 類支持 XPath,它是基于樹的分析(文檔對(duì)象模型)。

#!/usr/bin/ruby -w
 
require 'rexml/document'
include REXML
 
xmlfile = File.new("movies.xml")
xmldoc = Document.new(xmlfile)
 
# 第一個(gè)電影的信息
movie = XPath.first(xmldoc, "http://movie")
p movie
 
# 打印所有電影類型
XPath.each(xmldoc, "http://type") { |e| puts e.text }
 
# 獲取所有電影格式的類型,返回?cái)?shù)組
names = XPath.match(xmldoc, "http://format").map {|x| x.text }
p names

以上實(shí)例輸出結(jié)果為:

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

XSLT 和 Ruby

Ruby 中有兩個(gè) XSLT 解析器,以下給出簡(jiǎn)要描述:
Ruby-Sablotron

這個(gè)解析器是由正義Masayoshi Takahash編寫和維護(hù)。這主要是為L(zhǎng)inux操作系統(tǒng)編寫的,需要以下庫(kù):

  1.     Sablot
  2.     Iconv
  3.     Expat

你可以在 Ruby-Sablotron 找到這些庫(kù)。
XSLT4R
XSLT4R 由 Michael Neumann 編寫。 XSLT4R 用于簡(jiǎn)單的命令行交互,可以被第三方應(yīng)用程序用來(lái)轉(zhuǎn)換XML文檔。

XSLT4R需要XMLScan操作,包含了 XSLT4R 歸檔,它是一個(gè)100%的Ruby的模塊。這些模塊可以使用標(biāo)準(zhǔn)的Ruby安裝方法(即Ruby install.rb)進(jìn)行安裝。

XSLT4R 語(yǔ)法格式如下:

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

如果您想在應(yīng)用程序中使用XSLT4R,您可以引入XSLT及輸入你所需要的參數(shù)。實(shí)例如下:

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 )

相關(guān)文章

  • RUBY 新手教程 跟我一起學(xué)ruby

    RUBY 新手教程 跟我一起學(xué)ruby

    從今天起我就要開始學(xué)Ruby了。怎么樣,沒(méi)見吧?一個(gè)新人寫教程。就憑我堅(jiān)強(qiáng)的毅力,科學(xué)的自學(xué)方法,以及我的鉆研精神,我有信心學(xué)通Ruby,而同樣是新手的你也可以!
    2011-01-01
  • 創(chuàng)建自定義的Ruby gem包的教程

    創(chuàng)建自定義的Ruby gem包的教程

    這篇文章主要介紹了創(chuàng)建自定義的Ruby gem包的教程,包括作者編寫的一個(gè)簡(jiǎn)單實(shí)例,需要的朋友可以參考下
    2015-04-04
  • 提升Ruby on Rails性能的幾個(gè)解決方案

    提升Ruby on Rails性能的幾個(gè)解決方案

    這篇文章主要介紹了提升Ruby on Rails性能的幾個(gè)解決方案,本文來(lái)自于IBM官方網(wǎng)站技術(shù)文檔,需要的朋友可以參考下
    2015-04-04
  • Ruby中使用Nokogiri包來(lái)操作XML格式數(shù)據(jù)的教程

    Ruby中使用Nokogiri包來(lái)操作XML格式數(shù)據(jù)的教程

    這篇文章主要介紹了Ruby中使用Nokogiri包來(lái)操作XML格式數(shù)據(jù)的教程,Nokogiri是一個(gè)gem包,Nokogiri可以依靠XPath和CSS3選擇器方式來(lái)實(shí)現(xiàn)搜索功能,比較強(qiáng)大,需要的朋友可以參考下
    2016-04-04
  • 使用Ruby來(lái)處理JSON的簡(jiǎn)單教程

    使用Ruby來(lái)處理JSON的簡(jiǎn)單教程

    這篇文章主要介紹了使用Ruby來(lái)處理JSON的簡(jiǎn)單教程,用到了Ruby gem,需要的朋友可以參考下
    2015-04-04
  • Ruby on Rails框架程序連接MongoDB的教程

    Ruby on Rails框架程序連接MongoDB的教程

    在Rails中我們可以通過(guò)MongoMapper來(lái)使用MongoDB數(shù)據(jù)庫(kù),下面就來(lái)記錄一下Ruby on Rails框架程序連接MongoDB的教程,需要的朋友可以參考下
    2016-07-07
  • Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例

    Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例

    二分查找是一種在已經(jīng)過(guò)排序的數(shù)組中搜索指定元素用的算法,這里我們就來(lái)看一下Ruby實(shí)現(xiàn)二分搜索(二分查找)算法的簡(jiǎn)單示例:
    2016-07-07
  • ruby實(shí)現(xiàn)github第三方認(rèn)證

    ruby實(shí)現(xiàn)github第三方認(rèn)證

    GitHub在用戶認(rèn)證過(guò)程中采用了雙匙機(jī)制,在雙匙加密機(jī)制中,只有合法用戶才擁有私匙,只要GitHub在收到請(qǐng)求時(shí)可以證明提交請(qǐng)求的客戶端上擁有該私匙,即可以確認(rèn)該操作是由合法用戶發(fā)起的。我們通過(guò)ruby來(lái)簡(jiǎn)單模擬下吧。
    2015-06-06
  • Ruby中操作字符串的一些基本方法

    Ruby中操作字符串的一些基本方法

    這篇文章主要介紹了Ruby中操作字符串的一些基本方法,包括對(duì)字符串的壓縮和解壓縮等處理,需要的朋友可以參考下
    2015-05-05
  • Ruby實(shí)現(xiàn)郵件主動(dòng)推送觸發(fā)程序

    Ruby實(shí)現(xiàn)郵件主動(dòng)推送觸發(fā)程序

    這篇文章主要介紹了Ruby實(shí)現(xiàn)郵件主動(dòng)推送觸發(fā)程序,本文給出了客戶端輪詢和服務(wù)器主動(dòng)推送的代碼實(shí)例,需要的朋友可以參考下
    2015-01-01

最新評(píng)論