我希望,有人偶然发现了同样的问题,并可能会指导我找到一个简单的解决方案来解决我的问题。
我想定期检索一些关于我在 Facebook 上的广告的数据。基本上,我只想将一些元数据存储在我的一个数据库中,以供进一步报告。因此,我想为我的所有广告获取 AD-ID、AD-name 和相应的 ADSET-ID。
我用 Python 编写了这个小函数:
def get_ad_stats(ad_account):
""" Pull basic stats for all ads
Args: 'ad_account' is the Facebook AdAccount object
Returns: 'fb_ads', a list with basic values
"""
fb_ads = []
fb_fields = [
Ad.Field.id,
Ad.Field.name,
Ad.Field.adset_id,
Ad.Field.created_time,
]
fb_params = {
'date_preset': 'last_14_days',
}
for ad in ad_account.get_ads(fields = fb_fields, params = fb_params):
fb_ads.append({
'id': ad[Ad.Field.id],
'name': ad[Ad.Field.name],
'adset_id': ad[Ad.Field.adset_id],
'created_time': datetime.datetime.strptime(ad[Ad.Field.created_time], "%Y-%m-%dT%H:%M:%S+0000"),
})
return (fb_ads)
Campaign 和 AdSet 数据的类似功能可以正常工作。但是对于广告,我总是达到用户请求限制:"(#17) User request limit reached"
。
我确实有一个“BASIC”的 API 访问级别,我们在这里谈论的是 12,000 个广告。而且,不幸的是,异步调用似乎只适用于 Insights-edge。
有没有办法避免用户请求限制,例如通过将 API 请求限制为仅在特定日期左右之后更改/新创建的那些广告?