meta-ads-audit
Compare original and translation side by side
🇺🇸
Original
English🇨🇳
Translation
ChineseMeta Ads Audit
Meta Ads 审计
Diagnose Meta (Facebook + Instagram) account health and persist business context for downstream skills (). Read-only — never mutates the account. The user runs to execute fixes you recommend.
/meta-ads/meta-ads诊断Meta(Facebook + Instagram)账户健康状况,并为下游技能()留存业务上下文。只读模式——绝不会修改账户内容。用户需运行来执行你推荐的修复操作。
/meta-ads/meta-adsSetup
设置步骤
Follow — MCP detection, OAuth, ad account selection.
../shared/preamble.md遵循中的说明——MCP检测、OAuth授权、广告账户选择。
../shared/preamble.mdFilesystem contract (MUST persist)
文件系统约定(必须持久化)
| Artifact | Path | When |
|---|---|---|
| Business context | | First full audit, or refresh when |
| Personas | | Every full audit. |
These are the handoff to — write them even if the report itself is short. Otherwise downstream skills operate without business context and produce generic output.
/meta-adsIf a exists from (no subdir), read it as a starting point — most fields (services, brand voice, differentiators, locations, seasonality) are platform-agnostic. Then write the Meta-specific version to with any Meta-specific overrides (different creative angles, different audiences, different funnel events).
{data_dir}/business-context.json/google-ads-auditmeta/{data_dir}/meta/business-context.jsonbusiness-context.json schema (shared with Google Ads where fields apply):
.
business_name, industry, website, services[], locations[], target_audience, brand_voice{tone, words_to_use[], words_to_avoid[]}, differentiators[], competitors[], seasonality{peak_months[], slow_months[], seasonal_hooks[]}, social_proof[], offers_or_promotions[], landing_pages{}, unit_economics{aov_usd, profit_margin, ltv_usd, source}, notes, audit_date, account_idMeta-specific extensions:
.
meta_funnel_events{top_of_funnel, mid_of_funnel, conversion}, creative_inventory{concepts[], formats[], aspect_ratios[]}, custom_audiences{purchasers, abandoners, engagers, list_uploads[]}, pixel_health{pixel_id, capi_enabled, emq_score, last_event_at}personas JSON schema: . The Meta version adds (e.g. "before/after demonstration", "founder-led explainer", "UGC review") and (objects, settings, emotions that resonate with this persona). See .
{account_id, saved_at, personas: [{name, demographics, primary_goal, pain_points[], decision_trigger, value, meta_creative_angles[], visual_cues[]}]}meta_creative_anglesvisual_cuesreferences/persona-discovery.md| 产物 | 路径 | 时机 |
|---|---|---|
| 业务上下文 | | 首次完整审计时,或当 |
| 用户画像 | | 每次完整审计时生成。 |
这些文件是传递给的关键信息——即使报告本身篇幅较短,也必须写入这些文件。否则下游技能将缺乏业务上下文,只能生成通用输出。
/meta-ads如果存在来自的文件(无子目录),可将其作为起始参考——大多数字段(服务、品牌调性、差异化优势、地域、季节性)是平台无关的。随后将Meta特定版本写入,并添加Meta专属的覆盖配置(如不同的创意方向、受众群体、漏斗事件)。
/google-ads-audit{data_dir}/business-context.jsonmeta/{data_dir}/meta/business-context.jsonbusiness-context.json schema(与Google Ads共享适用字段):
。
business_name, industry, website, services[], locations[], target_audience, brand_voice{tone, words_to_use[], words_to_avoid[]}, differentiators[], competitors[], seasonality{peak_months[], slow_months[], seasonal_hooks[]}, social_proof[], offers_or_promotions[], landing_pages{}, unit_economics{aov_usd, profit_margin, ltv_usd, source}, notes, audit_date, account_idMeta专属扩展字段:
。
meta_funnel_events{top_of_funnel, mid_of_funnel, conversion}, creative_inventory{concepts[], formats[], aspect_ratios[]}, custom_audiences{purchasers, abandoners, engagers, list_uploads[]}, pixel_health{pixel_id, capi_enabled, emq_score, last_event_at}用户画像JSON schema: 。Meta版本新增了(例如“前后对比展示”、“创始人讲解”、“UGC测评”)和(与该用户画像共鸣的物品、场景、情绪)。详情请参阅。
{account_id, saved_at, personas: [{name, demographics, primary_goal, pain_points[], decision_trigger, value, meta_creative_angles[], visual_cues[]}]}meta_creative_anglesvisual_cuesreferences/persona-discovery.mdPolicy freshness check (run first)
政策新鲜度检查(优先执行)
Read . For each entry where :
../shared/policy-registry.jsonlast_verified + stale_after_days < today- High-volatility → WebSearch the for recent Meta Ads changes; compare to
area. If drift, banner the report and suggest registry update.assumption - Moderate-volatility → one-line "may warrant a check" note.
- Stable → skip silently.
The Meta platform changes faster than Google Ads (Advantage+, attribution, learning behaviors) — check high-volatility entries every audit.
读取文件。对于每个满足的条目:
../shared/policy-registry.jsonlast_verified + stale_after_days < today- 高波动性 → 针对进行Web搜索,查找Meta Ads的最新变化;与
area进行对比。若存在偏差,在报告中标记并建议更新注册表。assumption - 中等波动性 → 添加一行“可能需要检查”的注释。
- 稳定性 → 静默跳过。
Meta平台的变化速度快于Google Ads(如Advantage+、归因模型、学习行为)——每次审计都需检查高波动性条目。
Phase 1 — Pull the audit dataset
阶段1 — 提取审计数据集
Use a single call with to fan out the queries an audit needs. Build the fan-out from this rubric.
runScriptads.graphParallelA complete audit needs at minimum:
- Ad account info () — currency, timezone, business id, spend cap, account status, balance.
/{accountId} - Pixel health (+
/{accountId}/customconversions) — pixel id, last activity, CAPI status, Event Match Quality (EMQ) score./{accountId}/adspixels - Campaigns () — id, name, objective, status, daily/lifetime budget, special_ad_categories, buying_type, bid_strategy, created_time. Last 90 days.
/{accountId}/campaigns - Ad sets () — id, name, status, campaign_id, optimization_goal, billing_event, bid_strategy, daily_budget, lifetime_budget, attribution_spec, targeting (summary), promoted_object, learning_stage_info.
/{accountId}/adsets - Ads () — id, name, status, ad set, creative summary (image/video, primary text, headline, description, CTA), effective_status.
/{accountId}/ads - Insights at campaign level () — spend, impressions, reach, frequency, cpm, link CTR, link clicks, purchases (or other primary action), purchase value, ROAS, CPA.
ads.insights({level:"campaign", date_preset:"last_30d"}) - Insights at ad set level — same fields, last 30 days.
- Insights at ad level — top 50 ads by spend; same fields plus video metrics (3-sec views, ThruPlays) for video creatives.
- Insights with breakdowns — placement (), age/gender, device. Use these to spot placement losers and audience composition.
publisher_platform,platform_position - Recent edit activity — when available via last_modified or
/{adsetId}change history./{adsetId}
Compute aggregates in the script, return summarized JSON. Don't return all rows — rank, slice, summarize. The agent narrates the result; the script does the math.
suggestImprovementIf a critical query errors out (auth, schema, API version), surface the error and stop — don't fall back to a degraded audit.
Skip scoring entirely if or . Go straight to business context.
totalSpend == 0activeCampaigns == 0使用单个调用搭配来并行执行审计所需的查询。按照以下规则构建并行任务。
runScriptads.graphParallel完整审计至少需要以下数据:
- 广告账户信息 () — 货币、时区、企业ID、支出上限、账户状态、余额。
/{accountId} - 像素健康度 (+
/{accountId}/customconversions) — 像素ID、最后活动时间、CAPI状态、事件匹配质量(EMQ)分数。/{accountId}/adspixels - 广告系列 () — ID、名称、目标、状态、日预算/终身预算、特殊广告类别、购买类型、出价策略、创建时间。取最近90天的数据。
/{accountId}/campaigns - 广告组 () — ID、名称、状态、广告系列ID、优化目标、计费事件、出价策略、日预算、终身预算、归因规则、定向(摘要)、推广对象、学习阶段信息。
/{accountId}/adsets - 广告素材 () — ID、名称、状态、所属广告组、创意摘要(图片/视频、主文本、标题、描述、CTA)、有效状态。
/{accountId}/ads - 广告系列层级洞察数据 () — 支出、曝光量、覆盖人数、频次、CPM、链接点击率、链接点击量、购买量(或其他主要转化动作)、购买价值、ROAS、CPA。
ads.insights({level:"campaign", date_preset:"last_30d"}) - 广告组层级洞察数据 — 相同字段,取最近30天的数据。
- 广告素材层级洞察数据 — 按支出排名前50的广告素材;相同字段,视频创意额外包含视频指标(3秒观看量、ThruPlays)。
- 带细分维度的洞察数据 — 投放位置()、年龄/性别、设备。用于识别表现不佳的投放位置和受众构成。
publisher_platform,platform_position - 最近编辑活动 — 若的last_modified字段或
/{adsetId}的变更历史可用,则提取该数据。/{adsetId}
在脚本中计算聚合数据**,返回汇总后的JSON。不要返回所有原始行——需进行排名、截取、汇总。由Agent解读结果,脚本负责计算。
suggestImprovement若关键查询出错(授权、schema、API版本问题),需显示错误并停止审计——不要降级执行审计。
若满足以下条件则完全跳过评分: 或 。直接进入业务上下文阶段。
totalSpend == 0activeCampaigns == 0Phase 2 — Scope handling
阶段2 — 范围处理
If the user narrows the audit ("focus on one campaign", "campaign X", "just check creative fatigue"):
- Match campaign names by case-insensitive substring. If no match, list available campaigns and ask.
- Filter the in-memory dataset before scoring — no extra API calls.
- Account-level dimensions (Pixel health, attribution defaults) stay account-wide. Note "Scoped to: X" in the report.
- Skip Phase 4 (business context refresh) on scoped audits if is fresh.
business-context.json
若用户限定审计范围(如“聚焦某一个广告系列”、“广告系列X”、“仅检查创意疲劳”):
- 通过不区分大小写的子字符串匹配广告系列名称。若无匹配项,列出可用的广告系列并询问用户。
- 在评分前过滤内存中的数据集——无需额外调用API。
- 账户级维度(像素健康度、归因默认设置)仍保持账户范围。在报告中注明“审计范围:X”。
- 若为最新状态,范围限定型审计可跳过阶段4(业务上下文刷新)。
business-context.json
Phase 3 — Score
阶段3 — 评分
Score each of the 7 dimensions 0–5 using . Overall = .
references/account-health-scoring.mdround(sum × 100 / 35)| Score | Label | Meaning |
|---|---|---|
| 0 | Critical | Broken or missing — actively losing money |
| 1 | Poor | Major waste or missed opportunity |
| 2 | Needs Work | Several clear issues |
| 3 | Acceptable | Functional, room to improve |
| 4 | Good | Well-managed, minor opportunities |
| 5 | Excellent | Best-practice |
Scope-aware: campaign-level dimensions reflect in-scope data; account-level dimensions (Pixel + CAPI, attribution setup) score account-wide with a note on scope impact.
使用中的规则,对7个维度分别进行0–5分的评分。总分 = 。
references/account-health-scoring.mdround(sum × 100 / 35)| 分数 | 标签 | 含义 |
|---|---|---|
| 0 | 严重问题 | 功能损坏或缺失——正在持续亏损 |
| 1 | 较差 | 存在重大浪费或错失关键机会 |
| 2 | 需要改进 | 存在多个明确问题 |
| 3 | 可接受 | 功能正常,但有优化空间 |
| 4 | 良好 | 管理完善,仅存在少量优化机会 |
| 5 | 优秀 | 符合最佳实践 |
评分需考虑审计范围:广告系列级维度反映限定范围内的数据;账户级维度(像素+CAPI、归因设置)按全账户评分,并注明范围对评分的影响。
Encoded heuristics — apply these, they aren't obvious
内置启发式规则——需严格应用,这些规则并不直观
- Pixel + CAPI is upstream of everything. EMQ < 7.0 means Meta can't match events well — Smart Bidding starves regardless of how good the creative is. STOP-condition input.
- Reported ROAS systematically overstates true ROAS. Cross-check Meta-reported numbers against Shopify / GA4 / MMM where possible. The gap is the modeled-conversion premium and is typically 20–40% in ecom.
- Frequency × CPM trend = creative diagnosis. Frequency > 3.0 with CPM rising ≥ 30% w/w is fatigue — recommend creative refresh, not budget cuts.
- One ad set carrying > 70% of a campaign is fragility, not concentration. When it fatigues, the campaign collapses.
- Audience overlap > 50% between sibling ad sets fragments signal. Consolidate; don't try to "fix" with bid caps.
- Special Ad Category misclassification is a takedown risk, not just a policy nit. Surface as Critical regardless of current performance.
- Manual placements without evidence is a sign of inherited-from-2018 thinking. Default should be Advantage+ Placements; deviations need data.
- 像素+CAPI是所有环节的基础。EMQ < 7.0意味着Meta无法准确匹配事件——无论创意质量多好,智能出价都会受限。此为停止条件输入项。
- 报告的ROAS会系统性高估真实ROAS。尽可能将Meta报告的数据与Shopify / GA4 / MMM的数据交叉验证。两者的差距即为模型转化溢价,在电商领域通常为20–40%。
- 频次×CPM趋势 = 创意诊断。频次>3.0且CPM周环比上升≥30%表示创意疲劳——建议刷新创意,而非削减预算。
- 单个广告组贡献某广告系列超过70%的支出是脆弱性表现,而非集中化优势。当该广告组出现疲劳时,整个广告系列会崩溃。
- 兄弟广告组间受众重叠>50%会分散信号。应合并广告组;不要尝试用出价上限“修复”该问题。
- 特殊广告类别分类错误存在被下架风险,而非仅仅是政策细节问题。无论当前表现如何,均标记为严重问题。
- 无数据支撑的手动投放位置选择是过时的操作思路。默认应使用Advantage+ Placements;若需调整,必须有数据支持。
Pixel + Tracking Diagnosis Matrix
像素与追踪诊断矩阵
| EMQ < 5 | EMQ 5–6.9 | EMQ 7.0+ | |
|---|---|---|---|
| CAPI off | Critical — flying blind | Critical — most events lost | High — leaving 15–25% of events on the table |
| CAPI on, dedup off | Critical — duplicated and weak signal | High — duplicate counting risk | Medium — match quality improves with dedup |
| CAPI on, dedup on | High — match quality is the bottleneck | Medium — improve event_id coverage | Healthy |
| EMQ < 5 | EMQ 5–6.9 | EMQ 7.0+ | |
|---|---|---|---|
| CAPI未开启 | 严重问题——盲目投放 | 严重问题——大部分事件丢失 | 高优先级——损失15–25%的事件数据 |
| CAPI已开启,去重未开启 | 严重问题——数据重复且信号薄弱 | 高优先级——存在重复计数风险 | 中等优先级——开启去重可提升匹配质量 |
| CAPI已开启,去重已开启 | 高优先级——匹配质量是瓶颈 | 中等优先级——提升event_id覆盖率 | 健康状态 |
Phase 4 — Business context
阶段4 — 业务上下文
Derive what you can from the data already pulled:
| Field | Source |
|---|---|
| Ad account name ( |
| Top campaigns by spend, ad set names, top-converting ad creatives |
| Targeting geo summary (countries / regions in active ad sets) |
| Top-performing ad copy (primary text + headline) |
| Mix of image / video / carousel observed in active ads |
| Aspect ratios across active ads (1:1, 4:5, 9:16) |
| Most common optimization event on top-spending ad sets |
| Custom audiences referenced in active ad set targeting |
| From the Pixel detail call |
| Apex domain from active ad final URLs |
Then crawl the website (homepage + about + 1–2 top landing pages, parallel ) and merge into the schema. See for the full crawl procedure.
WebFetchreferences/business-context.mdAlways ask the user: differentiators, competitors, seasonality, AOV + profit margin (essential for ROAS-aware scoring). Ask for everything else only if data + crawl can't answer it.
从已提取的数据中推导尽可能多的信息:
| 字段 | 来源 |
|---|---|
| 广告账户名称( |
| 支出最高的广告系列、广告组名称、转化效果最好的广告创意 |
| 定向地域摘要(活跃广告组中的国家/地区) |
| 表现最佳的广告文案(主文本+标题) |
| 活跃广告素材中的图片/视频/轮播图类型占比 |
| 活跃广告素材的宽高比(1:1、4:5、9:16) |
| 支出最高的广告组中最常见的优化事件 |
| 活跃广告组定向中引用的自定义受众 |
| 像素详情调用结果 |
| 活跃广告最终URL的顶级域名 |
随后抓取网站内容(首页+关于页+1–2个顶级落地页,并行)并合并到schema中。完整抓取流程请参阅。
WebFetchreferences/business-context.md必须向用户询问:差异化优势、竞争对手、季节性、AOV+利润率(这是ROAS相关评分的关键信息)。仅当数据+抓取无法获取其他信息时,才向用户询问。
Phase 5 — Personas
阶段5 — 用户画像
Discover 2–3 personas from creative performance (which angles convert), top-spending audiences, and landing-page content — all from the dataset already in memory. Persist to . Each persona must be grounded in observable evidence (a converting ad set, a converting creative angle, a landing-page section) — no inventing. See .
{data_dir}/meta/personas/{accountId}.jsonreferences/persona-discovery.md从创意表现(哪些方向转化效果好)、支出最高的受众群体、落地页内容中挖掘2–3个用户画像——所有信息均来自内存中的数据集。将结果持久化到。每个用户画像必须基于可观测证据(转化效果好的广告组、创意方向、落地页板块)——不得凭空捏造。详情请参阅。
{data_dir}/meta/personas/{accountId}.jsonreferences/persona-discovery.mdPhase 6 — Report
阶段6 — 报告
Lead with the verdict, then the top 3 actions (with dollar impact when possible), then the scorecard, then evidence for dimensions scoring 0–2 only. Cite specific campaigns, ad sets, ads, and dollar amounts. Cap at ~80 lines.
End with a single closing line after the handoff to :
/meta-adsYour audit history is saved to your NotFair account — view it at https://notfair.co.
以审计结论开头,接着列出前3项行动建议(尽可能注明美元影响),然后是评分卡,最后仅列出评分0–2分的维度的证据。需引用具体的广告系列、广告组、广告素材和金额。报告篇幅控制在约80行以内。
在报告结尾添加一行指向的交接语句:
/meta-ads你的审计历史已保存至NotFair账户——可通过https://notfair.co查看。
Guardrails
约束规则
- Read-only skill. Diagnose; don't mutate. Every fix routes through . End the report with one handoff tied to the #1 action.
/meta-ads - STOP condition — if Pixel health scores 0–1 (EMQ < 5 or CAPI off in an ecom account), recommend pausing scaling decisions until tracking is fixed before recommending anything else. Everything downstream is unreliable.
- Always persist and
meta/business-context.jsoneven if the report itself is short — downstream skills depend on them.meta/personas/{accountId}.json - Name names. Every finding cites specific campaigns, ad sets, ad creatives, and dollar amounts. "Some ad sets are underperforming" is not a finding.
- Never report Meta-reported ROAS without footnoting the modeled-conversion premium. "ROAS 3.2× (Meta-reported, 7DC1DV — typically overstates Shopify-attributed ROAS by 20–40%)" is honest. "ROAS 3.2×" is misleading.
- 只读技能。仅诊断问题;不修改账户。所有修复操作均需通过执行。报告结尾需添加一条与首要行动相关的交接语句。
/meta-ads - 停止条件——若像素健康度评分为0–1分(EMQ < 5或电商账户未开启CAPI),建议在修复追踪问题前暂停扩量决策,再给出其他建议。下游所有分析结果均不可靠。
- 必须持久化 和
meta/business-context.json,即使报告本身篇幅较短——下游技能依赖这些文件。meta/personas/{accountId}.json - 明确指向具体对象。每个发现都需引用具体的广告系列、广告组、广告素材和金额。“部分广告组表现不佳”不属于有效发现。
- 报告Meta的ROAS数据时必须注明模型转化溢价。例如“ROAS 3.2×(Meta报告,7天点击1天转化——通常比Shopify归因的ROAS高估20–40%)”是准确的表述。仅写“ROAS 3.2×”具有误导性。