麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Ruby > 正文

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

2020-10-29 19:41:45
字體:
供稿:網(wǎng)友

什么是 XML ?

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

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

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

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

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

  1.     SAX解析器是基于事件處理的,需要從頭到尾把XML文檔掃描一遍,在掃描的過程中,每次遇到一個(gè)語法結(jié)構(gòu)時(shí),就會(huì)調(diào)用這個(gè)特定語法結(jié)構(gòu)的事件處理程序,向應(yīng)用程序發(fā)送一個(gè)事件。
  2.     DOM是文檔對(duì)象模型解析,構(gòu)建文檔的分層語法結(jié)構(gòu),在內(nèi)存中建立DOM樹,DOM樹的節(jié)點(diǎn)以對(duì)象的形式來標(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語言編寫的,遵守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 安裝,而無需單獨(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 解析器

讓我們先來解析 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.rootputs "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 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 解析器

處理相同的數(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}" endend list = MyListener.newxmlfile = 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來查看XML ,XPath 是一門在 XML 文檔中查找信息的語言(查看:XPath 教程)。

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

Ruby 通過 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, ThrillerAnime, Science FictionAnime, ActionComedy["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)用程序用來轉(zhuǎn)換XML文檔。

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

XSLT4R 語法格式如下:

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

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

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 )

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 日韩欧美视频一区二区三区 | 亚洲国产成人久久一区www妖精 | 九一传媒在线观看 | 欧美精品18 | 国产精品久久久久影院老司 | av7777777| 久久色在线 | av懂色| 欧美性受xxxxxx黑人xyx性爽 | 一级黄色片在线看 | 日本成人二区 | 国产小视频在线观看 | 在线中文字幕网站 | 激情视频免费观看 | 国产亚洲精品久久午夜玫瑰园 | 羞羞答答视频 | 韩国精品一区二区三区四区五区 | 国产美女视频黄a视频免费 日韩黄色在线播放 | 91福利影视 | 久草视频在线看 | 日韩精品中文字幕一区 | 日韩黄色免费观看 | 蜜桃91麻豆 | 一级做a爱片久久毛片a高清 | 精品国产99久久久久久宅男i | av黄色在线免费观看 | 欧美三级欧美成人高清www | 国产亚洲精品久久久久久久软件 | 久久精品亚洲欧美日韩精品中文字幕 | 特片网久久 | 91麻豆精品国产91久久久点播时间 | 国产一区亚洲 | 免费国产视频大全入口 | 国产精品夜色视频一级区 | 成人店女老板视频在线看 | 欧美77| 成人三级免费电影 | 一级黄色毛片免费 | 国产女同疯狂激烈互摸 | 毛片在线免费观看完整版 | 亚洲成人免费网站 |