我想使用API返回与我的搜索查询匹配的所有推文,但只返回在过去五秒内发布的推文。
使用Twitter的Search API,我可以使用since_id从特定ID中获取所有推文。但是,我真的看不到一个好的方法来找到推文的开头。
我也知道你可以在实际查询中使用“since:”来使用日期,但你不能输入时间。
有Twitter API经验的人可以给我任何建议吗?感谢阅读和你的时间!
答案 0 :(得分:4)
这听起来像你可以做的事情,因为created_at是结果集中返回的字段之一。只需进行查询,只使用最近5秒内的查询。
答案 1 :(得分:2)
<script type="text/javascript" charset="utf-8">
// JavaScript Document
$(document).ready(function(){
// start twitter API
$.getJSON('http://twitter.com/status/user_timeline/YOUR_NAME.json?count=10&callback=?', function(data){
$.each(data, function(index, item){
$('#twitter').append('<div class="tweet"><p>' + item.text.linkify() + '</p><p><strong>' + relative_time(item.created_at) + '</strong></p></div>');
});
});
function relative_time(time_value) {
var values = time_value.split(" ");
time_value = values[1] + " " + values[2] + ", " + values[5] + " " + values[3];
var parsed_date = Date.parse(time_value);
var relative_to = (arguments.length > 1) ? arguments[1] : new Date();
var delta = parseInt((relative_to.getTime() - parsed_date) / 1000);
delta = delta + (relative_to.getTimezoneOffset() * 60);
var r = '';
if (delta < 60) {
r = 'a minute ago';
} else if(delta < 120) {
r = 'couple of minutes ago';
} else if(delta < (45*60)) {
r = (parseInt(delta / 60)).toString() + ' minutes ago';
} else if(delta < (90*60)) {
r = 'an hour ago';
} else if(delta < (24*60*60)) {
r = '' + (parseInt(delta / 3600)).toString() + ' hours ago';
} else if(delta < (48*60*60)) {
r = '1 day ago';
} else {
r = (parseInt(delta / 86400)).toString() + ' days ago';
}
return r;
}
String.prototype.linkify = function() {
return this.replace(/[A-Za-z]+:\/\/[A-Za-z0-9-_]+\.[A-Za-z0-9-_:%&\?\/.=]+/, function(m) {
return m.link(m);
});
};// end twitter API
}); // ***** end functions *****
</script>
<div id="twitter">
Target Div
</div>
答案 2 :(得分:0)
您是否尝试实时推送推文?不是twitter对API req / hour有限制。我觉得你打得很快。
答案 3 :(得分:0)
为什么不每隔5秒调用一次API并获取前1条推文。
答案 4 :(得分:0)
Twitter API结果默认按最近排序。请参阅twitter wiki的以下引用:
Twitter搜索API的参数:
* Valid values include:
o mixed: In a future release this will become the default value. Include both popular and real time results in the response.
o recent: The current default value. Return only the most recent results in the response.
o popular: Return only the most popular results in the response.
* Example: http://search.twitter.com/search.atom?q=Twitter&result_type=mixed
* Example: http://search.twitter.com/search.json?q=twitterapi&result_type=popular
* Example: http://search.twitter.com/search.atom?q=justin+bieber&result_type=recent
如果我在任何地方都错了,请纠正我。
谢谢和问候,
Abhay Dandekar