apollo-core-workflow-a
Apollo.ioのリード検索およびデータ充実ワークフローを実装します。リード生成機能の構築、連絡先の検索、またはApolloからの見込み客データの充実が必要な場合に使用してください。「apollo lead search」「search apollo contacts」「find leads in apollo」「apollo people search」「enrich contacts apollo」などのフレーズでトリガーされます。
description の原文を見る
Implement Apollo.io lead search and enrichment workflow. Use when building lead generation features, searching for contacts, or enriching prospect data from Apollo. Trigger with phrases like "apollo lead search", "search apollo contacts", "find leads in apollo", "apollo people search", "enrich contacts apollo".
SKILL.md 本文
Apollo Core Workflow A: リード検索とデータ拡張
概要
リード検索とコンタクト/企業データの拡張のための Apollo.io プライマリワークフローを実装します。これは B2B セールスインテリジェンスのコア使用例です。
前提条件
apollo-sdk-patternsセットアップの完了- 有効な Apollo API 認証情報
- ターゲット市場の基準に関する理解
ワークフロー構成要素
1. 人物検索
企業、職位、所在地、業界などの様々な条件に基づいてコンタクトを検索します。
// src/services/apollo/people-search.ts
import { apollo } from '../../lib/apollo/client';
interface PeopleSearchCriteria {
domains?: string[];
titles?: string[];
locations?: string[];
industries?: string[];
employeeRanges?: string[];
page?: number;
perPage?: number;
}
export async function searchPeople(criteria: PeopleSearchCriteria) {
const response = await apollo.searchPeople({
q_organization_domains: criteria.domains,
person_titles: criteria.titles,
person_locations: criteria.locations,
q_organization_industry_tag_ids: criteria.industries,
organization_num_employees_ranges: criteria.employeeRanges,
page: criteria.page || 1,
per_page: criteria.perPage || 25,
});
return {
contacts: response.people.map(transformPerson),
pagination: response.pagination,
};
}
function transformPerson(person: any) {
return {
id: person.id,
name: person.name,
firstName: person.first_name,
lastName: person.last_name,
title: person.title,
email: person.email,
phone: person.phone_numbers?.[0]?.sanitized_number,
linkedin: person.linkedin_url,
company: {
id: person.organization?.id,
name: person.organization?.name,
domain: person.organization?.primary_domain,
},
};
}
2. 企業データ拡張
企業データを拡張して包括的なファーモグラフィック情報を取得します。
// src/services/apollo/company-enrichment.ts
import { apollo } from '../../lib/apollo/client';
export async function enrichCompany(domain: string) {
const response = await apollo.enrichOrganization(domain);
const org = response.organization;
return {
id: org.id,
name: org.name,
domain: org.primary_domain,
website: org.website_url,
industry: org.industry,
subIndustry: org.sub_industry,
employeeCount: org.estimated_num_employees,
annualRevenue: org.annual_revenue,
founded: org.founded_year,
description: org.short_description,
technologies: org.technologies || [],
locations: {
headquarters: {
city: org.city,
state: org.state,
country: org.country,
},
},
social: {
linkedin: org.linkedin_url,
twitter: org.twitter_url,
facebook: org.facebook_url,
},
};
}
3. コンタクト拡張
個人コンタクトをメールおよび追加データで拡張します。
// src/services/apollo/contact-enrichment.ts
export async function enrichContact(params: {
email?: string;
firstName?: string;
lastName?: string;
domain?: string;
linkedinUrl?: string;
}) {
const response = await apollo.enrichPerson({
email: params.email,
first_name: params.firstName,
last_name: params.lastName,
organization_domain: params.domain,
linkedin_url: params.linkedinUrl,
});
return {
...transformPerson(response.person),
enrichmentScore: calculateEnrichmentScore(response.person),
};
}
function calculateEnrichmentScore(person: any): number {
let score = 0;
if (person.email) score += 30;
if (person.phone_numbers?.length) score += 20;
if (person.linkedin_url) score += 15;
if (person.title) score += 10;
if (person.organization) score += 15;
if (person.city) score += 10;
return score;
}
4. リード生成パイプライン全体
// src/services/apollo/lead-pipeline.ts
import { searchPeople } from './people-search';
import { enrichCompany } from './company-enrichment';
import { enrichContact } from './contact-enrichment';
interface LeadCriteria {
targetDomains?: string[];
targetTitles: string[];
targetLocations?: string[];
targetIndustries?: string[];
minEmployees?: number;
maxEmployees?: number;
}
export async function generateLeads(criteria: LeadCriteria) {
// Step 1: Search for matching contacts
const searchResults = await searchPeople({
domains: criteria.targetDomains,
titles: criteria.targetTitles,
locations: criteria.targetLocations,
industries: criteria.targetIndustries,
});
// Step 2: Enrich companies for each unique domain
const uniqueDomains = [...new Set(
searchResults.contacts
.map(c => c.company.domain)
.filter(Boolean)
)];
const enrichedCompanies = await Promise.all(
uniqueDomains.slice(0, 10).map(async (domain) => {
try {
return await enrichCompany(domain);
} catch {
return null;
}
})
);
const companyMap = new Map(
enrichedCompanies
.filter(Boolean)
.map(c => [c!.domain, c])
);
// Step 3: Combine and filter results
return searchResults.contacts.map(contact => ({
...contact,
company: companyMap.get(contact.company.domain) || contact.company,
}));
}
使用例
// Example: Find engineering leads at fintech companies
const leads = await generateLeads({
targetTitles: ['VP Engineering', 'CTO', 'Engineering Manager'],
targetIndustries: ['financial services', 'fintech'],
minEmployees: 50,
maxEmployees: 500,
});
console.log(`Found ${leads.length} leads`);
leads.forEach(lead => {
console.log(`${lead.name} - ${lead.title} at ${lead.company.name}`);
});
出力
- ページネーション対応の人物検索結果
- 拡張された企業ファーモグラフィックデータ
- メールを含む拡張されたコンタクトデータ
- スコアリング付きの統合リードパイプライン
エラーハンドリング
| エラー | 原因 | 解決策 |
|---|---|---|
| 空の結果 | 検索条件が狭すぎる | 検索パラメータを拡大してください |
| メールなし | コンタクトがデータベースにない | LinkedIn データ拡張を試してください |
| レート制限 | データ拡張呼び出しが多すぎる | バッチ処理を実装してください |
| 無効なドメイン | ドメインが存在しない | 最初にドメインを検証してください |
リソース
次のステップ
メールシーケンスとアウトリーチについては apollo-core-workflow-b に進んでください。
ライセンス: MIT(寛容ライセンスのため全文を引用しています) · 原本リポジトリ
詳細情報
- 作者
- Brmbobo
- リポジトリ
- Brmbobo/Web2podcast
- ライセンス
- MIT
- 最終更新
- 2026/1/26
Source: https://github.com/Brmbobo/Web2podcast / ライセンス: MIT
関連スキル
seo-maps
ローカルSEO向けのマップインテリジェンス機能です。ジオグリッドのランク追跡、APIを通じたGBPプロフィール監査、Google・Tripadvisor・Trustpilotなど複数プラットフォームのレビュー分析、Google・Bing・Apple・OSM間のNAP(名前・住所・電話番号)検証、競合他社の半径マッピング、APIデータからのLocalBusinessスキーマ生成が可能です。3段階の機能レベルで対応でき、無料版(Overpass + Geoapify)、DataForSEO(フル機能)、DataForSEO + Google(最大カバレッジ)から選択できます。「maps」「geo-grid」「rank tracking」「GBP audit」「review velocity」「competitor radius」「maps analysis」「local rank tracking」「Share of Local Voice」「SoLV」などのキーワードで利用できます。
seo-content-brief
セクションごとの文字数、競合スコアリング、キーワード密度ガイダンス、ページタイプテンプレートを含む競争力のあるSEOコンテンツブリーフを生成します。新規ページのブリーフと既存ページの改善ブリーフの両方に対応しています。ユーザーが「コンテンツブリーフ」「ブリーフを作成」「コンテンツアウトライン」「ブログブリーフ」「サービスページブリーフ」「ブリーフ〜」「ライティングブリーフ」「コンテンツプラン」「アウトライン〜」などと言った場合に使用します。
rakuten-seo
楽天市場の商品名・キャッチコピーをSEO最適化するスキル。「楽天SEO」「商品名最適化」「楽天の商品名」「キャッチコピー」「楽天のタイトル」「商品名を直して」「楽天検索対策」など、楽天市場の商品名やキャッチコピーの作成・改善・チェックに関するリクエストで必ずこのスキルを使う。既存の商品名の改善も、ゼロからの作成も対応。あらゆるジャンル(食品・ファッション・化粧品・家電・サプリ・インテリア・ベビー・ペット・業務用など)に対応。 【ALSEL独自スキル】株式会社ALSEL が、19年・5,000社超の EC 支援で得たノウハウをもとに開発したオリジナルスキルです。
amazon-seo-jp
Amazon.co.jp商品ページのSEO分析・最適化・自動採点スキル v2.0。 COSMO/Rufus/A10アルゴリズムに基づく採点。セラーセントラル出品レポート(.xlsm)を入力すると、 商品タイトル・箇条書き・検索キーワード・商品説明文を100点満点で採点し、 4項目すべての改善案を日本語で出力する。 トリガー: 「Amazon SEO」「商品ページ採点」「Amazon最適化」 「リスティング改善」「Amazon商品名」「箇条書き改善」 「COSMO対応」「Rufus最適化」「Amazon タイトル」 【ALSEL独自スキル】株式会社ALSEL が、19年・5,000社超の EC 支援で得たノウハウをもとに開発したオリジナルスキルです。
rakuten-bulk-control-csv
楽天RMSの一括登録/一括除外/一括更新用CSV(コントロールカラム,商品管理番号 の2列フォーマット)を作成するスキル。商品DL CSV・商品管理画面のコピペ・Excel・PDFなどから商品管理番号を抽出し、Shift-JIS+LF改行で出力する。「一括除外リスト作って」「楽天の除外CSV」「コントロールカラムnで」「2800円以下の商品をdで」「在庫0の商品を一括削除」「商品管理番号抜いてshift-jsで」「このフォーマットで」など、楽天RMSの商品一括処理用CSVを作るタスクで必ずこのスキルを使う。コントロールカラム値(n=新規/d=削除/u=更新)と抽出条件(全件・価格・在庫・販売状態など)をユーザー指示に応じて柔軟に切り替える。 【ALSEL独自スキル】株式会社ALSEL が、19年・5,000社超の EC 支援で得たノウハウをもとに開発したオリジナルスキルです。
amazon-a-plus-content-brief
Amazon A+コンテンツの構成・モジュール選定・画像指示・比較表・FAQを設計するスキル。「A+コンテンツ作って」「Aプラス構成」「ブランドストーリー」「比較表つきA+」「A+モジュール選定」「Amazonのページに画像入れたい」「A+のヘッダー画像」「A+コンテンツマネージャー」など、Amazon A+コンテンツの企画・設計・改善のリクエストで必ずこのスキルを使う。ベーシック17モジュール/Premium追加機能/画像サイズ規定/文字数目安/審査リジェクト要因を踏まえて、デザイナーに渡せるブリーフ形式で出力。あらゆるジャンル(家電・コスメ・食品・アパレル・日用品・ベビー・ペット等)に対応。※ブランドストア(マルチページ)の設計は別スキル `amazon-brand-store-planner`、タイトル・bullet改善は `amazon-title-bullet-rewriter-jp`、メイン画像のチェックは `amazon-main-image-checker`。 【ALSEL独自スキル】株式会社ALSEL が、19年・5,000社超の EC 支援で得たノウハウをもとに開発したオリジナルスキルです。