我对我制作的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();
}
所以,至少,我很乐意回答这个简单的问题:假设我拥有所有必需的API权限(我当然这样做),给定广告ID,我该怎么办?检索"帖子"的ID该广告中有哪些内容?
理想情况下,我喜欢回答的问题是:如何在一个API查询中检索该帖子ID,因为我正在检索我想要的所有见解(如上所示)?
谢谢!
答案 0 :(得分:5)
事实是,帖子ID是一个基本的广告参数,而不是您从洞察中获得的每日价值。这就是为什么它无法在洞察端点的任何地方找到。
假设您知道所有广告ID,您可以一次查询所有广告ID(单个请求中的金额可能会有一些未记录的限制),如下所示:
/v2.8/?ids=6068303632680,6074066638080&fields=creative{effective_object_story_id}
这实际上是执行这两个查询的快捷方式
/v2.8/6068303632680?fields=creative{effective_object_story_id}
/v2.8/6074066638080?fields=creative{effective_object_story_id}
您可以在多个ID读取请求
部分找到有关高级API使用情况here in FB docs的更多信息答案 1 :(得分:0)
如果您想将Facebook广告ID与Facebook视频ID相关联,您可以使用类似的查询。
/v2.9/6087224935451?fields=creative{ name, title, video_id, status }
<强>结果:强>
{
"creative": {
"name": "Ad from a Page post 24",
"video_id": "745639641594227",
"status": "ACTIVE",
"id": "6087045300251"
},
"id": "6087224935451"
}