2010-11-20 2 views
8

次のHTMLでは、Nokogiriを使って解析して結果を得たいと思います。divをNokogiriを使ってdivに入れます。

event_name = "folk concert 2" 
event_link = "http://www.douban.com/event/12761580/"  
event_date = "20th,11,2010" 

私はdoc.xpath('//div[@class="nof clearfix"]')が各div要素を得ることができる知っているが、どのように私はevent_nameのように、それぞれの帰属を取得するために進むべき、特にdate

HTML

<div class="nof clearfix">   
      <h2><a href="http://www.douban.com/event/12761580/">folk concert 2</a> <span class="pl2"> </span></h2> 
      <div class="pl intro"> 
       Date:25th,11,2010<br/> 
      </div> 
</div> 
<div class="nof clearfix">   
      <h2><a href="http://www.douban.com/event/12761581/">folk concert </a> <span class="pl2"> </span></h2> 
      <div class="pl intro"> 
       Date:10th,11,2010<br/> 
      </div> 
</div> 

答えて

15

私はCSSセレクタを使用することを好む、XPathを知らない、彼らは私に多くの意味をなします。 This tutorialが役に立ちます。

require 'rubygems' 
require 'nokogiri' 
require 'pp' 

Event = Struct.new :name , :link , :date 

doc = Nokogiri::HTML DATA 

events = doc.css("div.nof.clearfix").map do |eventnode| 
    name = eventnode.at_css("h2 a").text.strip 
    link = eventnode.at_css("h2 a")['href'] 
    date = eventnode.at_css("div.pl.intro").text.strip 
    Event.new name , link , date 
end 

pp events 


__END__ 
<div class="nof clearfix">   
     <h2><a href="http://www.douban.com/event/12761580/">folk concert 2</a> <span class="pl2"> </span></h2> 
      <div class="pl intro"> 
      Date: 25th,11,2010<br/> 
      </div> 
</div> 
<div class="nof clearfix">   
     <h2><a href="http://www.douban.com/event/12761581/">folk concert </a> <span class="pl2"> </span></h2> 
      <div class="pl intro"> 
      Date: 10th,11,2010<br/> 
      </div> 
</div> 

この出力:私は完璧に動作

[#<struct Event 
    name="folk concert 2", 
    link="http://www.douban.com/event/12761580/", 
    date="Date: 25th,11,2010">, 
#<struct Event 
    name="folk concert", 
    link="http://www.douban.com/event/12761581/", 
    date="Date: 10th,11,2010">] 
+0

。ありがとう。 – pierrotlefou

関連する問題