Twitter4j:搜索和跟踪之间的差异

时间:2017-02-03 09:14:30

标签: java twitter4j

我从Twitter4j开始,我需要使用特定的主题标签从Stream获取Tweet。

我发现了两种方法:

StatusListener listener = new StatusListener() {
...
    public void onStatus(Status status) {
                statuses.add(status);
                HashtagEntity[] H = status.getHashtagEntities();
                System.out.println(statuses.size()+":Got tweet:\n" + status.getText()+"\n"+status.getUser().getScreenName()
                        + " | "+status.getId()+" | "+H.length+"\n");
                if(H.length>0){
                    for(int i=0;i<H.length-1;i++){
                        System.out.print(H[i]+"");
                    }
                }
                if (statuses.size() > nbremax) {
                    synchronized (lock) {
                        lock.notify();
                    }
                    System.out.println("unlocked");
                }
            }
}
FilterQuery fq = new FilterQuery();    
fq.track("#hashtag");
TwitterStream twitterStream = ...;
twitterStream.addListener(listener);
twitterStream.filter(fq);

Twitter twitter = ...;
Query query = new Query("#hastag");
QueryResult result = twitter.search(query);
for (Status status : result.getTweets()) {
    HashtagEntity[] H = status.getHashtagEntities();
    System.out.println("Got tweet:\n" + status.getText()
            +"\n"+status.getUser().getScreenName()+ " | "+status.getId()+
            " | retweet ? "+status.isRetweet()+" | "+H.length);
    System.out.println(status.getCreatedAt()+" | "+status.getGeoLocation()+
                    " | "+status.getPlace()+" | "+status.getSource());
    if(H.length>0){
        for(int i=0;i<H.length;i++){
            System.out.print(H[i].getText()+" ; ");
            if(i==H.length-1){
               System.out.println("\n");
            }
        }
    }

它们之间的区别是什么?哪种方法最适合搜索特定的标签?

1 个答案:

答案 0 :(得分:0)

搜索:您将检索包含给定主题标签现在所有现有推文。

跟踪:包含给定主题标签的所有推文将流式传输给您从现在开始