facebook api之Ads Insights API
The Ads Insights API
provides API access for reporting and analytics purposes.
When exclusively using the Ad Insights API, request the ads_read
permission.
1. Marketing API Quickstart
2. Example Query: Campaign Statistics
3. All References
# Next Steps
1. Marketing API Quickstart
To get started with the Marketing API, start by creating an app.
Once created, you can add Marketing API as a product and go through the Quickstart experience within your app dashboard.
Marketing API Quickstart simplifies using the Marketing API by generating sample code for you.
It is a step-by-step on-boarding flow that helps you use ad management and insights tools built on Facebook's Marketing API.
You can start getting insights from your Facebook Pixel or App Ads SDKs by clicking the Create Ad reports below.
#To get the statistics of a campaign's last 7 day performance run the following query:
curl -G \
-d "date_preset=last_7_days" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<AD_CAMPAIGN_ID>/insights"
To learn more about how to query statistics, see the ad insights edge documentation.
3. All References
The Ads Insights API has the following references that we strongly recommend to read:
Insights
This insights edge provides a single, consistent interface to retrieve an ad's statistics.
- Parameters - Parameters available on this endpoint.
- Fields - Options for in the
fields
parameter for this endpoint. - Breakdowns - Group results from API calls
- Action Breakdowns - Understanding the response from action breakdowns.
- Async Jobs - For requests with large results, use asynchronous jobs
- Limits and Best Practices - Explains Insights API call limits, filtering and best practices.
- Metrics Names and API Fields - Metrics Names in Facebook Ads tools with corresponding API fields.
Making A Call
The Insights API is available as an edge on any ads object.
API Method |
---|
|
|
|
|
#You can request specific fields with a comma-separated list in the fields parameters:
curl -G \
-d "fields=impressions" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<AD_OBJECT_ID>/insights"
Levels
Aggregate results at a defined object level. This automatically deduplicates data.
# get a campaign's insights on ad level.
curl -G \
-d "level=ad" \
-d "fields=impressions,ad_id" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<CAMPAIGN_ID>/insights"
If you don't access to all the ad objects at the requested level, the insights call returns no data.
For example, while requesting insights with level as ad, if you don't have access to one or more ad objects under the ad account, this api call will return a permission error.
Attribution Windows
The conversion attribution window provides timeframes that define when we attribute an event to an ad on Facebook.
For background information, see Facebook Ads Help Center, How Attribution Reporting Works.
We measure the actions that occur when a conversion event occurs and look back in time 1-day, 7-days, and 28 days.
To view actions attributed to different attribution windows, make a request to /{ad-account-id}/insights
.
If you do not provide action_attribution_windows
we use 28d_click
and 1d_view
and provide it under 'value'.
#For example specify action_attribution_windows and 'value' is fixed at 28d_click and 1d_view attribution windows.
# Make a request to act_10151816772662695/insights?action_attribution_windows=['1d_click','1d_view']
Field Expansion
Request fields at the node level and by fields specified in field expansion:
curl -G \
-d "fields=insights{impressions}" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<AD_ID>"
Sorting
Sort results by providing the sort
parameter with {fieldname}_descending
or {fieldname}_ascending
:
curl -G \
-d "sort=reach_descending" \
-d "level=ad" \
-d "fields=reach" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<ADSET_ID>/insights"
Ads Labels
Stats for all labels whose names are identical.
Aggregated into a single value at an ad object level.
curl -G \
-d "fields=id,name,insights{unique_clicks,cpm,total_actions}" \
-d "level=ad" \
-d 'filtering=[{"field":"ad.adlabels","operator":"ANY", "value":["Label Name"]}]' \
-d 'time_range={"since":"2015-03-01","until":"2015-03-31"}' \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<AD_OBJECT_ID>/insights"
Clicks Definition
To better understand the three click metrics that Facebook offers today, please read the definitions and usage of each below:
Link Clicks,
actions:link_click
- The number of clicks on ad links to select destinations or experiences, on or off Facebook-owned properties. See Ads Help Center, Link ClicksClicks (All),
clicks
- The metric counts multiple types of clicks on your ad, including certain types of interactions with the ad container, links to other destinations, and links to expanded ad experiences. See Ads Help Center, Clicks(All)
Deleted and Archived Objects
Ad units may be DELETED
or ARCHIVED
.
The stats of deleted or archived objects appear when you query their parents.
This means if you query impressions
at the ad set level, results include impressions
from all ads in the set it, regardless of whether the the ads are in a deleted or archived state.
See also, Storing and Retrieving Ad Objects Best Practice.
However if you query at a certain level, such as level=ad
, objects that have been archived
or deleted
do not appear.
As the result, the total stats of the parent node may be greater than the stats of its children.
By default, ARCHIVED
objects are not included in the response of the insights edge, such as act_<AD_ACCOUNT_id>/insights?level=ad
.
You can get the stats of ARCHIVED
objects from their parent nodes though, by providing an extra filtering
parameter.
#To get the stats of all ARCHIVED ads in an ad account listed one by one:
curl -G \
-d "level=ad" \
-d "filtering=[{'field':'ad.effective_status','operator':'IN','value':['ARCHIVED']}]" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/act_<AD_ACCOUNT_ID>/insights/" #You can query insights on deleted objects if you have their IDs or by using the ad.effective_status filter. For example, if you have the ad set ID: curl -G \
-d "fields=id,name,status,insights{impressions}" \
-d "access_token=<ACCESS_TOKEN>" \
"https://graph.facebook.com/<API_VERSION>/<ADSET_ID>" #In this example, we query with ad.effective_status:
POST https://graph.facebook.com/<VERSION>/act_ID/insights?access_token=token&appsecret_proof=proof&fields=ad_id,impressions&date_preset=lifetime&level=ad&filtering=[{"field":"ad.effective_status","operator":"IN","value":["DELETED"]}]
Troubleshooting
Timeouts
The most common issues causing failure at this endpoint are too many requests and time outs:
- On
/GET
or synchronous requests, you can get out-of-memory or timeout errors. - On
/POST
or asynchronous requests, you can possibly get timeout errors. For asynchronous requests, it can take up to an hour to complete a request including retry attempts. For example if you make a query that tries to fetch large volume of data for many ad level objects.
Recommendations
- There is no explicit limit for when a query will fail. When it times out, try to break down the query into smaller queries by putting in filters like date range.
- Unique metrics are time consuming to compute. Try to query unique metrics in a separate call to improve performance of non-unique metrics.
Rate Limiting
The Facebook Insights API utilizes rate limiting to ensure an optimal reporting experience for all of our partners. For more information and suggestions, see our Insights API Limits & Best Practices.
facebook api之Ads Insights API的更多相关文章
- facebook api之Business Manager API
Business-scoped Users - The new user is tied to a particular business and has permissions scoped to ...
- API Monitor简介(API监控工具)
API Monitor是一个免费软件,可以让你监视和控制应用程序和服务,取得了API调用. 它是一个强大的工具,看到的应用程序和服务是如何工作的,或跟踪,你在自己的应用程序的问题. 64位支持 API ...
- Request Entity Too Large for Self Hosted ASP.Net Web API在Selfhost的api后台怎么解决Request Entity Too Large问题
Request Entity Too Large for Self Hosted ASP.Net Web API在Selfhost的api后台怎么解决Request Entity Too Large问 ...
- 使用 WSO2 API Manager 管理 Rest API
WSO2 API Manager 简介 随着软件工程的增多,越来越多的软件提供各种不同格式.不同定义的 Rest API 作为资源共享,而由于这些 API 资源的异构性,很难对其进行复用.WSO2 A ...
- Zookeeper C API 指南四(C API 概览)(转)
上一节<Zookeeper C API 指南三(回调函数)>重点讲了 Zookeeper C API 中各种回调函数的原型,本节将切入正题,正式讲解 Zookeeper C API.相信大 ...
- Atitit.一个cms有多少少扩展点,多少api wordpress cms有多少api。。扩展点
Atitit.一个cms有多少少扩展点,多少api wordpress cms有多少api..扩展点 1. Api分类 WordPress APIs1 1.1. 1 函数分类2 1.2. 函数api ...
- ASP.NET Web API与Rest web api(一)
HTTP is not just for serving up web pages. It is also a powerful platform for building APIs that exp ...
- ASP.NET Web API与Rest web api(一)
本文档内容大部分来源于:http://www.cnblogs.com/madyina/p/3381256.html HTTP is not just for serving up web pages. ...
- [Web API] 如何让 Web API 统一回传格式以及例外处理[转]
[Web API] 如何让 Web API 统一回传格式以及例外处理 前言 当我们在开发 Web API 时,一般的情况下每个 API 回传的数据型态或格式都不尽相同,如果你的项目从头到尾都是由你一个 ...
随机推荐
- 【Hadoop学习之三】Hadoop全分布式安装
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk8 hadoop3.1.1 全分布式就是集群,注意配置主机名. ...
- CachedIntrospectionResults 初始化
- 按渠道计算 PV 和 UV
按渠道计算 PV 和 UV: ------------------按指定channel_id按月求PV.UV------------ drop table if exists tmp_pvuv; cr ...
- USB接口案例——多态和转型
其中,为传递和使用的匿名对象,即创建了对象,但是没有引用类和对象名来接收: 电脑类中的操作usb的成员方法中,要向下转型,毛主席讲的具体问题具体分析,不同的设备有不同的操作:
- flask模板的基本用法(定界符、模板语法、渲染模板),模板辅助工具(上下文、全局对象、过滤器、测试器、模板环境对象)
flask模板 在动态web程序中,视图函数返回的HTML数据往往需要根据相应的变量(比如查询参数)动态生成. 当HTML代码保存到单独的文件中时,我们没法再使用字符串格式化或拼接字符串的当时在HTM ...
- POJ 1330 Nearest Common Ancestors(LCA Tarjan算法)
题目链接:http://poj.org/problem?id=1330 题意:给定一个n个节点的有根树,以及树中的两个节点u,v,求u,v的最近公共祖先. 数据范围:n [2, 10000] 思路:从 ...
- Python+OpenCV图像处理(十一)—— 图像金字塔
简介:图像金字塔是图像中多尺度表达的一种,最主要用于图像的分割,是一种以多分辨率来解释图像的有效但概念简单的结构.简单来说,图像金字塔就是用来进行图像缩放的. 进行图像缩放可以用图像金字塔,也可以使用 ...
- Python 监控脚本(硬盘、cpu、内存、网卡、进程)
#磁盘使用率disk = psutil.disk_partitions()for i in disk: print "磁盘:%s 分区格式:%s"%(i.device,i ...
- 高级架构进阶之HashMap源码就该这么学
引言--面试常见的问题 问:“你用过HashMap,你能跟我说说它吗?” “当然用过,HashMap是一种<key,value>的存储结构,能够快速将key的数据put方式存储起来,然后很 ...
- 如何使用Wisdom RESTClient定制满足您个性化需求的API文档?
Wisdom RESTClient 支持自动化测试RESTful API,输出精美的测试报告,生成精美的RESTful API文档. 这里介绍一下如何定制个性化的RESTful API文档. 定制个性 ...