使用分页从 FB 广告 API 检索异步广告洞察结果

retrieve async ads insights results from FB ads API with pagination

我正在使用 facebook-python-ads-sdk to make async calls for FB insights API as described

params = {
    "time_increment": 1,
    "level": "ad",
    "date_preset": "last_28d",
    "breakdowns": "hourly_stats_aggregated_by_advertiser_time_zone",
    "limit": 1000
}

job = AdAccount("id").get_insights_async(params=params)
result_cursor = wait_for_async_job(job)
results = [item for item in result_cursor]

def wait_for_async_job(job):
    for _ in range(TIMEOUT):
        time.sleep(1)
        job = job.remote_read()
        status = job[AdReportRun.Field.async_status]
        if status == "Job Completed":
            return job.get_result()

因此检索 last_28d 的见解的工作会在几分钟内完成,但是,对结果进行分页最多可能需要一个小时!

这是对异步作业进行分页的正确方法吗?

我发布答案是为了帮助遇到同样问题的其他开发者。

修改:

return job.get_result()

至:

return job.get_result(params={"limit": 1000})

这将以 1000 次而不是默认值 25 次为单位对结果进行分页。

以上更改为我们节省了 30 分钟 运行。

今天我遇到了同样的问题,这段代码对我有用

from facebook_business.adobjects.campaign import Campaign
from facebook_business.adobjects.adreportrun import AdReportRun
from facebook_business.adobjects.adsinsights import AdsInsights
import time

campaign = Campaign(<CAMPAIGN_ID>)

params = {
    'level': AdsInsights.Level.campaign,
}
async_job = campaign.get_insights(params=params, is_async=True)
async_job.api_get()
while while async_job[AdReportRun.Field.async_status]!= 'Job Completed':
     time.sleep(1)
     async_job.api_get()
time.sleep(1)
print(async_job.get_result())

替换

return job.get_result(params={"limit": 1000})

list(async_job.get_result())

始终获得所有响应。 get_result() 是一个迭代器。