ツイートをアーカイブする Ruby コードを書きましたが、いくつか質問があります。
1. 私のコードは効率が悪いようですが、リファクタリングを手伝ってもらえますか?
2. Twitter エラーの処理方法がよくわかりません。標準テキストだけでなく、スローされている特定のエラーを出力したいと思います。
3. レート制限ステータス コードの使用方法がわかりません。私のコードは常にまったく同じことを吐き出します:「次の 59 分 59 秒間に 150 個の Twitter API リクエストが残っています」
ありがとう!
require 'twitter'
count = 1
query = "hello"
res = Twitter.search(query, :rpp => 1, :result_type => "recent", :page => 1).results
search_id = res.first.id
loop do
begin
res = Twitter.search(query, :rpp => 100, :result_type => "recent", :page => 1, :max_id => search_id).results
res.each do |status|
puts "#{status.id}, #{status.created_at}, #{status.from_user}, #{status.text}"
puts count.to_s
count = count+1
end
search_id = res.last.id-1
rescue Twitter::Error => e
rate_limit_status = Twitter.rate_limit_status
puts "#{rate_limit_status.remaining_hits} Twitter API request(s) remaining for the next #{((rate_limit_status.reset_time - Time.now) / 60).floor} minutes and #{((rate_limit_status.reset_time - Time.now) % 60).round} seconds"
puts "Error: No more tweets to collect."
puts e.inspect
puts "Last tweet collected at #{res.last.created_at}"
break
end
end