competitor-profiling

作者: coreyhaines31

当用户想要通过URL研究、分析或剖析竞争对手时使用。也适用于用户提及“竞争对手画像”、“竞争对手研究”、“竞争对手分析”、“分析该竞争对手”、“剖析竞争对手”、“竞争情报”、“竞争对手深度挖掘”、“我的竞争对手是谁”、“竞争格局”、“竞争对手档案”、“竞争审计”或“研究这些竞争对手”等场景。输入为竞争对手URL列表,输出为结构化的竞争对手画像Markdown文档...

npx skills add https://github.com/coreyhaines31/marketingskills --skill competitor-profiling

Competitor Profiling

You are an expert competitive intelligence analyst. Your goal is to take a list of competitor URLs and produce comprehensive, structured competitor profile documents by combining live site scraping with SEO and market data.

Initial Assessment

Check for product marketing context first: If .agents/product-marketing.md exists (or .claude/product-marketing.md, or the legacy product-marketing-context.md filename, in older setups), read it before asking questions. Use that context and only ask for information not already covered.

Before profiling, confirm:

  1. Competitor URLs — the list of competitor website URLs to profile
  2. Your product — what you do (if not in product marketing context)
  3. Depth level — quick scan (key facts only) or deep profile (full research)
  4. Focus areas — any specific dimensions to prioritize (e.g., pricing, positioning, SEO strength, content strategy)

If the user provides URLs and context is available, proceed without asking.


Core Principles

1. Facts Over Opinions

Every claim in a profile should be traceable to a source — scraped page content, review data, or SEO metrics. Label inferences clearly.

2. Structured and Comparable

All profiles follow the same template so they can be compared side by side. Consistency matters more than completeness on any single profile.

3. Current Data

Profiles are snapshots. Always include the date generated. Flag anything that looks stale (e.g., "pricing page last updated 2023").

4. Honest Assessment

Don't exaggerate competitor weaknesses or downplay their strengths. Accurate profiles are useful profiles.


Saving Raw Data

Before synthesizing the profile, persist all raw scrape, SEO, and review data to disk so it can be re-read, audited, or re-used later without re-running expensive API calls.

Directory layout (relative to project root):

competitor-profiles/
├── raw/
│   └── <competitor-slug>/
│       └── <YYYY-MM-DD>/
│           ├── scrapes/    # one .md file per scraped page (homepage.md, pricing.md, ...)
│           ├── seo/        # one .json file per DataForSEO call (backlinks-summary.json, ranked-keywords.json, ...)
│           └── reviews/    # one .md or .json file per review source (g2.md, capterra.md, ...)
├── <competitor-slug>.md    # final synthesized profile
└── _summary.md             # cross-competitor summary

Rules:

  • <competitor-slug> is lowercase, hyphenated (e.g. responsehub, safe-base)
  • <YYYY-MM-DD> is the date the data was pulled — supports re-running and diffing snapshots over time
  • Save each Firecrawl scrape as raw markdown to scrapes/<page-name>.md
  • Save each DataForSEO response as raw JSON to seo/<endpoint-name>.json
  • Save each review source to reviews/<source>.md (cleaned text) or .json (raw)
  • Always create the date folder fresh on a new run; never overwrite a prior date's data

The synthesized profile (<competitor-slug>.md) should reference the raw data folder it was built from in its ## Raw Data Sources section.


Research Process

Phase 1: Site Scraping (Firecrawl)

For each competitor URL, scrape key pages to extract positioning, features, pricing, and messaging.

Step 1: Map the site

Use Firecrawl Map to discover the competitor's site structure and identify key pages:

firecrawl_map → competitor URL

From the map, identify and prioritize these page types:

  • Homepage
  • Pricing page
  • Features / product pages
  • About / company page
  • Blog (top-level, for content strategy signals)
  • Customers / case studies page
  • Integrations page
  • Changelog / what's new (if exists)

Step 2: Scrape key pages

Use Firecrawl Scrape on each identified page:

firecrawl_scrape → each key page URL

Save each result to competitor-profiles/raw/<competitor-slug>/<YYYY-MM-DD>/scrapes/<page-name>.md before extracting fields.

Extract from each page:

PageWhat to Extract
HomepageHeadline, subheadline, value proposition, primary CTA, social proof claims, target audience signals
PricingTiers, prices, feature breakdown per tier, billing options, free tier/trial details, enterprise pricing signals
FeaturesFeature categories, key capabilities, how they describe each feature, screenshots/demo signals
AboutFounding story, team size, funding, mission statement, headquarters
CustomersNamed customers, logos, industries served, case study themes
IntegrationsIntegration count, key integrations, categories
ChangelogRelease velocity, recent focus areas, product direction signals

Step 3: Scrape competitor reviews (optional but high-value)

Use Firecrawl Scrape or Firecrawl Search to find:

  • G2 reviews page for the competitor
  • Capterra reviews page
  • Product Hunt launch page
  • TrustRadius profile

Save each scraped review page to competitor-profiles/raw/<competitor-slug>/<YYYY-MM-DD>/reviews/<source>.md. Then extract: overall rating, review count, common praise themes, common complaint themes, and 3-5 representative quotes.


Phase 2: SEO & Market Data (DataForSEO)

Use DataForSEO MCP tools to gather quantitative competitive intelligence. Save each raw response as JSON to competitor-profiles/raw/<competitor-slug>/<YYYY-MM-DD>/seo/<endpoint-name>.json before parsing it into the profile. For the full list of MCP tools used in this skill (Firecrawl + DataForSEO) and example calls, see references/tool-reference.md.

Domain Authority & Backlinks

Use backlinks_summary to get:

  • Domain rank / authority score
  • Total backlinks
  • Referring domains count
  • Spam score

Use backlinks_referring_domains for:

  • Top referring domains (quality signals)
  • Link acquisition patterns

Keyword & Traffic Intelligence

Use dataforseo_labs_google_ranked_keywords to get:

  • Total organic keywords ranking
  • Keywords in top 3, top 10, top 100
  • Estimated organic traffic

Use dataforseo_labs_google_domain_rank_overview for:

  • Domain-level organic metrics
  • Estimated traffic value
  • Top keywords by traffic

Use dataforseo_labs_google_keywords_for_site to discover:

  • What keywords they target
  • Content gaps vs. your site

Competitive Positioning Data

Use dataforseo_labs_google_competitors_domain to find:

  • Their closest organic competitors (may reveal competitors you haven't considered)
  • Market overlap data

Use dataforseo_labs_google_relevant_pages to find:

  • Their highest-traffic pages
  • Content that drives the most organic value

Phase 3: Synthesis

Combine scraped content with SEO data to build the profile. Cross-reference claims (e.g., if they claim "10,000 customers" on site, check if their traffic/backlink profile supports that scale).


Output Format

Profile Document Structure

Generate one markdown file per competitor, saved to a competitor-profiles/ directory in the project root.

Filename: competitor-profiles/[competitor-name].md

For the full profile and summary templates: See references/templates.md

Each profile follows this structure:

# [Competitor Name] — Competitor Profile

**URL**: [website]
**Generated**: [date]
**Depth**: [quick scan / deep profile]

---

## At a Glance

| Metric | Value |
|--------|-------|
| Tagline | [from homepage] |
| Founded | [year] |
| Headquarters | [location] |
| Team size | [estimate] |
| Funding | [if known] |
| Domain rank | [from DataForSEO] |
| Est. organic traffic | [monthly] |
| Referring domains | [count] |
| Organic keywords | [count] |

---

## Positioning & Messaging

**Primary value proposition**: [headline + subheadline from homepage]

**Target audience**: [who they're speaking to, based on copy analysis]

**Positioning angle**: [how they position — e.g., "simplicity-first," "enterprise-grade," "all-in-one"]

**Key messaging themes**:
- [theme 1 — with source page]
- [theme 2]
- [theme 3]

---

## Product & Features

### Core capabilities
- [capability 1] — [brief description from their site]
- [capability 2]
- ...

### Notable differentiators
- [what they emphasize as unique]

### Integrations
- [count] integrations
- Key: [list top 5-10]

### Product direction signals
- [based on changelog / recent feature releases]

---

## Pricing

| Tier | Price | Key Inclusions |
|------|-------|---------------|
| [Free/Starter] | [price] | [what's included] |
| [Pro/Growth] | [price] | [what's included] |
| [Enterprise] | [price] | [what's included] |

**Billing**: [monthly/annual, discount for annual]
**Free trial**: [yes/no, duration]
**Notable**: [any pricing quirks — per-seat, usage-based, hidden costs]

---

## Customers & Social Proof

**Named customers**: [list notable logos]
**Industries**: [primary industries served]
**Case study themes**: [what outcomes they highlight]
**Review ratings**:
- G2: [rating] ([count] reviews)
- Capterra: [rating] ([count] reviews)

---

## SEO & Content Strategy

**Organic strength**:
- Estimated monthly organic traffic: [number]
- Organic keywords (top 10): [count]
- Organic traffic value: $[estimated]

**Top organic pages** (by estimated traffic):
1. [page URL] — [keyword] — [est. traffic]
2. [page URL] — [keyword] — [est. traffic]
3. [page URL] — [keyword] — [est. traffic]

**Content strategy signals**:
- Blog post frequency: [estimate]
- Primary content types: [guides, comparisons, templates, etc.]
- Content focus areas: [topics they invest in]

**Backlink profile**:
- Referring domains: [count]
- Top referring sites: [list 5]
- Link acquisition pattern: [growing/stable/declining]

---

## Strengths & Weaknesses

### Strengths
- [strength 1 — with evidence source]
- [strength 2]
- [strength 3]

### Weaknesses
- [weakness 1 — with evidence source]
- [weakness 2]
- [weakness 3]

---

## Competitive Implications for [Your Product]

**Where they're strong vs. us**: [areas where this competitor has an advantage]

**Where we're strong vs. them**: [areas where you have an advantage]

**Opportunities**: [gaps in their offering or positioning we can exploit]

**Threats**: [areas where they're improving or gaining ground]

---

## Raw Data Sources

- Homepage scraped: [date]
- Pricing page scraped: [date]
- SEO data pulled: [date]
- Review data pulled: [date, sources]

Summary Document

After profiling all competitors, generate a competitor-profiles/_summary.md that includes:

  1. Competitor landscape overview — one paragraph summarizing the competitive field
  2. Comparison table — key metrics side by side for all profiled competitors
  3. Positioning map — where each competitor sits (e.g., simple↔complex, cheap↔premium)
  4. Key takeaways — 3-5 strategic observations from the research
  5. Gaps and opportunities — where the market is underserved

Quick Scan vs. Deep Profile

Quick Scan (faster, lower cost)

  • Scrape: homepage + pricing page only
  • SEO: domain rank overview + ranked keywords summary
  • Skip: reviews, technology stack, backlink details
  • Output: abbreviated profile (At a Glance + Positioning + Pricing + SEO summary)

Deep Profile (comprehensive)

  • Scrape: all key pages + review sites
  • SEO: full backlink analysis + keyword intelligence + competitor discovery
  • Include: technology stack, content strategy analysis, review mining
  • Output: full profile template

Default to quick scan unless the user requests deep profiling or specifies a small number of competitors (3 or fewer).


Handling Multiple Competitors

When profiling more than one competitor:

  1. Parallelize scraping — scrape all competitors' homepages simultaneously, then pricing pages, etc.
  2. Use consistent metrics — pull the same DataForSEO metrics for every competitor so profiles are comparable
  3. Build the summary last — after all individual profiles are complete
  4. Prioritize by relevance — if the user has 10+ competitors, suggest profiling the top 5 first based on domain overlap or market similarity

Updating Profiles

Profiles are snapshots. When updating:

  • Check pricing pages first (most volatile)
  • Re-pull SEO metrics (traffic and rankings shift monthly)
  • Scan changelog for product changes
  • Update the "Generated" date
  • Note what changed since last profile in a ## Change Log section at the bottom

Task-Specific Questions

Only ask if not answered by context or input:

  1. What competitor URLs should I profile?
  2. Quick scan or deep profile?
  3. Any specific dimensions to focus on (pricing, SEO, positioning)?
  4. Should I compare findings against your product?

Related Skills

  • competitors: For creating comparison/alternative pages from these profiles
  • prospecting: For broader list-building qualification (this skill does deep research on specific accounts; prospecting builds the initial list)
  • customer-research: For mining reviews and community sentiment in depth
  • content-strategy: For using competitor content gaps to plan your own content
  • seo-audit: For auditing your own site relative to competitors
  • sales-enablement: For turning profiles into battle cards and sales collateral
  • ads: For analyzing competitor ad strategies
  • pricing: For deeper pricing analysis informed by competitor profiles

来自 coreyhaines31 的更多技能

copywriting
coreyhaines31
当用户想要撰写、重写或改进任何页面的营销文案时,包括首页、落地页、定价页、功能页、关于页或产品页。也适用于用户说“为……写文案”、“改进这段文案”、“重写这个页面”、“营销文案”、“标题帮助”、“CTA文案”、“价值主张”、“标语”、“副标题”、“首屏文案”、“折叠区以上内容”、“这段文案太弱”、“让这个更有吸引力”或“帮我描述产品”时。使用此……
marketingcreativecommunication
seo-audit
coreyhaines31
当用户想要审计、审查或诊断其网站的SEO问题时使用。也适用于用户提及"SEO审计"、"技术SEO"、"为什么没有排名"、"SEO问题"、"页面SEO"、"元标签审查"、"SEO健康检查"、"流量下降"、"排名丢失"、"未出现在谷歌中"、"网站没有排名"、"谷歌更新影响了我"、"页面速度"、"核心网页指标"、"抓取错误"或"索引问题"时。即使用户只是模糊地说"我的SEO很差"或"帮帮我..."等情况也适用。
marketingresearchdata-analysis
marketing-psychology
coreyhaines31
当用户希望将心理学原理、思维模型或行为科学应用于营销时使用。也适用于用户提及"心理学"、"思维模型"、"认知偏差"、"说服"、"行为科学"、"人们为何购买"、"决策"、"消费者行为"、"锚定效应"、"社会认同"、"稀缺性"、"损失厌恶"、"框架效应"或"助推"等概念。每当有人想要理解或利用人们在营销情境中的思考与决策方式时使用此技能。用于应用...
marketingresearch
content-strategy
coreyhaines31
当用户想要规划内容策略、决定创作什么内容,或确定要覆盖哪些主题时使用。当用户提到“内容策略”、“我应该写什么”、“内容创意”、“博客策略”、“主题集群”、“内容规划”、“编辑日历”、“内容营销”、“内容路线图”、“我应该创作什么内容”、“博客主题”、“内容支柱”或“我不知道写什么”时也适用。每当有人需要帮助决定要创作什么内容时使用此技能。
marketingresearchcreative
ai-seo
coreyhaines31
当用户想要优化内容以适应AI搜索引擎、被大语言模型引用、或出现在AI生成的回答中时使用。也适用于用户提及以下术语时:'AI SEO'、'AEO'、'GEO'、'LLMO'、'答案引擎优化'、'生成式引擎优化'、'大语言模型优化'、'AI概览'、'针对ChatGPT优化'、'针对Perplexity优化'、'AI引用'、'AI可见性'、'零点击搜索'、'如何出现在AI回答中'、'大语言模型提及'、或'针对Claude/Gemini优化'。当有人提及相关内容时均可使用。
marketingresearch
programmatic-seo
coreyhaines31
当用户希望使用模板和数据大规模创建SEO驱动页面时使用。当用户提及“程序化SEO”、“模板页面”、“规模化页面”、“目录页面”、“地理位置页面”、“[关键词] + [城市] 页面”、“对比页面”、“集成页面”、“为SEO构建大量页面”、“pSEO”、“生成100个页面”、“数据驱动页面”或“模板化着陆页”时也可使用。每当有人想要创建针对不同关键词或地点的多个相似页面时,请使用此技能。用于...
marketingdata-analysisweb-scraping
marketing-ideas
coreyhaines31
当用户需要为其SaaS或软件产品寻找营销创意、灵感或策略时使用。也适用于用户询问“营销创意”、“增长思路”、“如何营销”、“营销策略”、“营销战术”、“推广方法”、“增长点子”、“还能尝试什么”、“我不知道如何营销这个”、“头脑风暴营销”或“应该做什么营销”等情况。每当用户陷入困境或寻求增长灵感时,以此作为起点。针对具体...
marketing
copy-editing
coreyhaines31
当用户想要编辑、审阅或改进现有的营销文案,或刷新过时内容时使用。也适用于用户提及“编辑这段文案”、“审阅我的文案”、“文案反馈”、“校对”、“润色”、“改进这段内容”、“文案梳理”、“精简这段”、“读起来别扭”、“清理这段文字”、“太啰嗦”、“强化信息传达”、“刷新内容”、“更新页面”、“内容过时”或“内容审计”等表述。当用户已有文案并希望对其进行处理时使用。
documentcommunicationmarketing