Ruby中的Mechanize的使用教程_ruby專題

來源:互聯網
上載者:User

Ruby中實現網頁抓取,一般用的是mechanize,使用非常簡單。

安裝

複製代碼 代碼如下:

sudo gem install mechanize

抓取網頁
複製代碼 代碼如下:

require 'rubygems'
require 'mechanize'
agent = Mechanize.new
page = agent.get('http://google.com/')

類比點擊事件
複製代碼 代碼如下:

page = agent.page.link_with(:text => 'News').click

類比表單提交
複製代碼 代碼如下:

google_form = page.form('f')
google_form["q"] = 'ruby mechanize'
page = agent.submit(google_form, google_form.buttons.first)
pp page

分析頁面,mechanize用的是nokogiri解析網頁的,所以可以參照nokogiri的文檔
複製代碼 代碼如下:

table = page.search('a')
text = table.inner_text
puts text

有幾點注意的地方: 如果需要先登入的網頁,那麼可以在網站先登入,登入後記錄JSESSIONID,然後賦值給agent
複製代碼 代碼如下:

cookie = Mechanize::Cookie.new("JSESSIONID", "BA58528B76124698AD033EE6DF12B986:-1")
cookie.domain = "datamirror.csdb.cn"
cookie.path = "/"
agent.cookie_jar.add!(cookie)

如果需要儲存網頁,使用.save_as,(或許save也可以,我沒試過)例如
複製代碼 代碼如下:

agent.get("http://google.com").save_as

小技巧

puts Mechanize::AGENT_ALIASES 可以列印出所有可用的user_agent
puts Mechanize.instance_methods(false) 輸出Mechanize模組的所有方法
puts Mechanize.instance_methods()   輸出Mechanize模組的所有方法以及所繼承的類的函數

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.