XML-анализ Nokogiri с помощью Rails - PullRequest
5 голосов
/ 15 октября 2010

Я посмотрел на множество срезок, но этот кажется, что я оказался там, где я

контроллер

  def index
      require 'nokogiri'
      doc = Nokogiri::XML(open("http://sports.yahoo.com/top/rss.xml"))

      @links = doc.xpath('//item').map do |i|
      {'title' => i.xpath('title'), 'link' => i.xpath('link'), 'description' => i.xpath('description')}
      end
  end

просмотр

<ul>
  <%= debug @links.each.first %>
</ul>

debug out put

{"title"=>[#<Nokogiri::XML::Element:0x8199ce34 name="title" children=[#<Nokogiri::XML::Text:0x8199c6f0 "Kolb to get start for Eagles vs. Falcons (AP)">]>], "description"=>[#<Nokogiri::XML::Element:0x8199b660 name="description" children=[#<Nokogiri::XML::Text:0x8199a594 "Kevin Kolb will make his second straight start in place of the injured Michael Vick when the Philadelphia Eagles host Atlanta on Sunday. Eagles coach Andy Reid says Vick practiced Friday for the first time since sustaining a rib cartilage injury on Oct. 3. There's a chance Vick will be the backup quarterback against his former team.">]>], "link"=>[#<Nokogiri::XML::Element:0x81999f40 name="link" children=[#<Nokogiri::XML::Text:0x81999b58 "http://us.rd.yahoo.com/sports/rss/top/SIG=11npql9k5/*http%3A//sports.yahoo.com/nfl/news?slug=ap-eagles-qbs">]>]}

Мне нужно перебрать массив ссылок и получить доступ к хешу с заголовком и ссылкой, но я не знаю, как это сделатьчто.

1 Ответ

11 голосов
/ 15 октября 2010

Если я правильно понимаю, вам просто нужно получить внутренний текст из узлов xpath.

{'title' => i.xpath('title').inner_text,
 'link' => i.xpath('link').inner_text, 
 'description' => i.xpath('description').inner_text 
}

.......

...