Rya*_*yan 2 facebook facebook-graph-api facebook-ads-api
我对自己构建的Facebook广告报告工具感到非常满意。
它列出了一个广告帐户中的所有广告系列,以及每个广告系列中的所有广告集,以及每个广告集中的所有广告。
它显示了我关心的指标。
但是我一直无法弄清楚如何从广告中检索帖子ID。
似乎该字段未在Insights边缘中提及(在中不可用InsightsFields),因此也许我必须在另一个API调用上进行“加入”。
我获取见解的主要代码是:
public function getInsights($levelType, $id, $aggLevel, $start, $end) {
if ($levelType) {
if ($id == null) {
abort(500, 'You must provide the ID for the object you want to retrieve.');
}
} else {
$levelType = \AdAccount::class;
$id = ACT_PREPEND . $this->fbConfig['account_id'];
$aggLevel = AdsInsightsLevelValues::CAMPAIGN;
}
$variableClassWithNamespace = '\FacebookAds\Object\\' . $levelType;
$level = new $variableClassWithNamespace($id);
$fields = [
InsightsFields::CAMPAIGN_ID,
InsightsFields::CAMPAIGN_NAME,
InsightsFields::ADSET_ID,
InsightsFields::ADSET_NAME,
InsightsFields::AD_ID,
InsightsFields::AD_NAME,
InsightsFields::SPEND,
InsightsFields::UNIQUE_IMPRESSIONS,
InsightsFields::INLINE_LINK_CLICKS,
InsightsFields::INLINE_LINK_CLICK_CTR,
InsightsFields::COST_PER_INLINE_LINK_CLICK,
InsightsFields::ACTIONS,
InsightsFields::COST_PER_ACTION_TYPE,
InsightsFields::CPM,
];
$params = [
AdReportRunFields::LEVEL => $aggLevel,
];
if ($start) {
$params[AdReportRunFields::TIME_RANGE]['since'] = $start;
if (!$end) {
$params[AdReportRunFields::TIME_RANGE]['until'] = (new \DateTime("+2 year"))->format('Y-m-d');
}
}
if ($end) {
$params[AdReportRunFields::TIME_RANGE]['until'] = $end;
if (!$start) {
$params[AdReportRunFields::TIME_RANGE]['since'] = (new \DateTime("-1 year"))->format('Y-m-d');
}
}
if (!$start && !$end) {
$params[AdReportRunFields::DATE_PRESET] = InsightsPresets::LIFETIME;
}
$insights = $level->getInsights($fields, $params);
return $insights->getResponse()->getBody();
}
Run Code Online (Sandbox Code Playgroud)
因此,我至少愿意回答这个简单的问题:假设我拥有所有必需的API权限(我当然会这样做),给定广告ID,如何检索“帖子”的ID在该广告中展示?
理想情况下,我最想回答的是:如何在检索所需的所有见解时(如上所示)在一个API查询中检索该Post ID?
谢谢!
关键在于,帖子ID是基本的广告参数,而不是您从见解中获得的每日价值。这就是为什么在见解端点上的任何地方都找不到它的原因。
假设您知道所有广告ID,则可以一次查询所有广告ID(单个请求中的数量可能有一些未记录的限制),如下所示:
/v2.8/?ids=6068303632680,6074066638080&fields=creative{effective_object_story_id}
Run Code Online (Sandbox Code Playgroud)
实际上,这是执行这两个查询的捷径
/v2.8/6068303632680?fields=creative{effective_object_story_id}
/v2.8/6074066638080?fields=creative{effective_object_story_id}
Run Code Online (Sandbox Code Playgroud)
您可以在FB文档的“ 多个ID读取请求”部分中找到有关高级API使用的更多信息。
| 归档时间: |
|
| 查看次数: |
2427 次 |
| 最近记录: |