1

如果您有read_stream权限并且您获得了 facebook 用户的帖子,那么对于每个帖子,您只会获得前 X 条评论和前 X 条喜欢。有没有办法对喜欢/评论进行分页并全部获取?

如果有任何 FQL 查询可以返回帖子的所有喜欢或评论,或者让我一次翻阅 20 次左右,那也可以。

4

2 回答 2

3

编辑:

您必须获得每个状态才能获得对该状态的所有评论/喜欢。如果您有想要评论的特定帖子:

$post     = '100003978045030_105596009583000';
$comments = array();
$done     = false;
$options  = array();
$path     = '/' . $post . '/comments';

while(!$done){
    try{
        $data = $facebook->api($path, 'GET', $options);
    } catch(FacebookApiException $e) {
        echo $e->getMessage();
        $data = null;
        $done = true;
    }
    if(!is_null($data)){
        $comments = array_merge($comments, $data['data']);
        if(isset($data['paging']['next']) && !empty($data['paging']['next'])){
            $parts = parse_url($data['paging']['next']);
            $path  = $parts['path'];
            parse_str($parts['query'], $options);
        } else {
            $done = true;
        }
    }
}

print_r($comments);
于 2012-06-15T01:47:39.817 回答
1

在 FQL 中,您只需查询评论或点表:

SELECT post_id, text, fromid FROM comment 
   WHERE post_id IN 
      (SELECT post_id FROM stream WHERE source_id = USER_OR_PAGE_ID
       AND comments.count > 0 )
   LIMIT 0, 100

这将为您提供前 100 个结果(但可能会返回少于 100 个,因为您不可见的将被过滤掉)。

请注意,对于页面流,like 表是蹒跚的。

于 2012-06-15T02:01:10.660 回答