13

グラフAPIをテストしていて、問題が発生しました。ページ/グループの写真からカウントを取得するにはどうすればよいですか?

私はグループの管理者/作成者です。https://developers.facebook.com/tools/explorer/にそのグループの特定の写真IDを入力すると、コメントも含めてほぼすべてのデータが表示されますが、同様の数は表示されません。同様の部分については、誰でもその情報にアクセスできるという事実にもかかわらず、(ドキュメントによると)アクセストークンが必要です。

必要な権限を持つページ/グループのアクセストークンを取得する方法と、それを使用して必要な情報を取得する方法は?

可能であれば、単一のアドレスからJSONを取得したいと思います。

4

4 に答える 4

28

これはページで可能であり(アクセストークンがなくても!)、その方法は次のとおりです。

グラフのページにアクセス

ページのURLに移動して、ページのIDを取得します。

https://www.facebook.com/pages/platform/19292868552

URLの末尾の数字は、ページのIDです。そのIDを取得して、グラフエクスプローラー(ここ)で使用するか、直接アクセスしてください。

ページのアルバムにアクセス

そのURLにアルバムを追加すると、壁の写真を含む、ページにあるすべてのアルバムが表示されます。

https://graph.facebook.com/19292868552/albums

出力は次のようになります。

{
   "data": [
      {
         "id": "10150160810478553",
         "from": {
            "name": "Facebook Platform",
            "category": "Product/service",
            "id": "19292868552"
         },
         "name": "Bringing Operation Developer Love to Europe",
         "description": "Blog post: http://developers.facebook.com/blog/post/479\n\nVideos and presentations uploaded here: http://developers.facebook.com/videos/",
         "location": "Berlin, Paris, London",
         "link": "https://www.facebook.com/album.php?fbid=10150160810478553&id=19292868552&aid=285301",
         "cover_photo": "10150160811078553",
         "count": 32,
         "type": "normal",
         "created_time": "2011-04-06T23:05:44+0000",
         "updated_time": "2011-04-06T23:33:20+0000",
         "comments": {
         ..... etc ....

アルバムを選ぶ

データ配列内のオブジェクトごとに、 ID名前があります。これらの2つのフィールドを使用して、必要な写真を含むアルバムを選択できます。この結果の最初のアルバムは「ヨーロッパにオペレーション開発者の愛をもたらす」です。このアルバムの写真を見てみましょう。

写真を見る

この時点まで答えに従った場合、次のステップはかなり明白なはずです。必要なアルバムのIDを使用して、グラフのURLに写真を追加します。

https://graph.facebook.com/10150160810478553/photos

写真のいいねを見る

アルバムを選択するのと同じように、上記の手順の出力でIDを使用し、URLにいいねを追加して写真のいいねを表示します

https://graph.facebook.com/10150160813853553/likes

出力:

{
   "data": [
      {
         "id": "1163036945",
         "name": "Aditya Pn"
      },
      {
         "id": "1555885347",
         "name": "Nadin M\u00f6ller"
      },
      {
         "id": "100001643068103",
         "name": "Umut Ayg\u00fcn"
      },
      {
         "id": "100000165334510",
         "name": "Alessandra Milfont"
      },
      {
         "id": "100001472353494",
         "name": "Sayer Mohammad Naz"
      },
      {
         "id": "1051008973",
         "name": "Jenson Daniel Chambi"
      },
      {
         "id": "100000233515895",
         "name": "Ruby Atiga"
      },

この出力を使用すると、データ配列内のエントリの数を単純にカウントして、同様のカウントを取得できます。


これはすべて、出力ボックスと接続サイドバーのIDをクリックしてグラフエクスプローラーを使用することで可能になることに注意してください最後/ likes接続は、すぐに追加されることを願っています。これがお役に立てば幸いです。また、ページは公開されているため、これを行うにはアクセストークンが必要です。これがお役に立てば幸いです。

于 2011-08-11T16:57:58.597 に答える
6

fieldsパラメータを。と組み合わせて使用​​することで、すべてのいいねをページ分割することなく、コメント/いいねの数を取得できますlikes.limit(1).summary(true)。たとえば、以下のピザのAPIクエリを検索すると、すべての公開投稿とそのいいねの数が要約されます。

https://graph.facebook.com/search?q=pizza&type=post&fields=id,name,likes.limit(1).summary(true)

結果(切り捨て):

{
  "data": [
    {
      "id": "47883936273_659693910762305", 
      "name": "Instagram", 
      "created_time": "2014-02-16T01:15:29+0000", 
      "likes": {
        "data": [
          {
            "id": "100002243084532", 
            "name": "Yvette Martin"
          }
        ], 
        "paging": {
          "cursors": {
            "after": "MTAwMDAyMjQzMDg0NTMy", 
            "before": "MTAwMDAyMjQzMDg0NTMy"
          }, 
          "next": "https://graph.facebook.com/47883936273_659693910762305/likes?limit=1&summary=1&after=MTAwMDAyMjQzMDg0NTMy"
        }, 
        "summary": {
          "total_count": 13682
        }
      }
    }, 
    {
      "id": "136336876521150_314001148754721", 
      "name": "Pizza Box Turns into Plates & Storage Unit!", 
      "created_time": "2014-02-15T21:20:00+0000", 
      "likes": {
        "data": [
          {
            "id": "100005373008864", 
            "name": "Liliana Campoli"
          }
        ], 
        "paging": {
          "cursors": {
            "after": "MTAwMDA1MzczMDA4ODY0", 
            "before": "MTAwMDA1MzczMDA4ODY0"
          }, 
          "next": "https://graph.facebook.com/136336876521150_314001148754721/likes?limit=1&summary=1&after=MTAwMDA1MzczMDA4ODY0"
        }, 
        "summary": {
          "total_count": 2792
        }
      }
    }
于 2014-02-20T20:12:00.713 に答える
1

/ me/feedはLIKESフィールドを返します

LIKESを表示する配列内のアイテムの数を単純に見つけるソリューションを使用しました

Object.keys(item.likes.data).length

これは、オブジェクトの「長さ」を返します。これは、いいねの数と同じです。

于 2014-04-18T18:10:51.470 に答える
-1

http://graph.facebook.com/223766074374957

応答にいいねプロパティがあります

{
   "name": "Bejeweled Blitz",
   "is_published": true,
   "website": "https://apps.facebook.com/bejeweledblitz/",
   "username": "bejeweledblitz",
   "products": "Bejeweled Blitz\nBejeweled\nPlants vs. Zombies\nPeggle\nZuma\nChuzzle\nBookworm Adventures\n \nFor a complete list, please visit www.popcap.com\n ",
   "about": "We're the award-winning hit, Bejeweled Blitz! The lightning-fast puzzle game where you have just 60-seconds to match as many gems as you can! Start Blitzing now!",
   "general_info": "Speed is the name of the game in Bejeweled Blitz! Bejeweled Blitz is a speedier take on the classic Bejeweled match-3 gem game mechanic. Your goal is to make as many matches as you can in 60-seconds to really make your score soar! But you won't be going it alone! There are special ways to enhance your Bejeweled Blitz game - like Boosts (power-ups like Scrambler, which moves all the gems around the board or +5 seconds, to add 5 seconds more gem-matching time!) and the popular, Rare Gems. Rare Gems are like extra-special power-ups that can REALLY take your game to the next level!",
   "talking_about_count": 22487,
   "category": "App page",
   "id": "223766074374957",
   "link": "https://www.facebook.com/bejeweledblitz",
   "likes": 5796324,
   "cover": {
      "cover_id": 383412771743619,
      "source": "http://sphotos-c.ak.fbcdn.net/hphotos-ak-ash4/s720x720/417018_383412771743619_1056862875_n.jpg",
      "offset_y": 0
   }
}
于 2012-11-30T04:46:38.213 に答える