enrich-industry
关于
This HubSpot workflow skill automatically copies industry data from company records to their associated contacts, enabling industry-based segmentation for targeted B2B campaigns. It bridges the common data gap where companies have industry data but contacts do not. Use it to feed ICP classification, lead scoring, and send relevant messaging instead of generic email blasts.
快速安装
Claude Code
推荐npx skills add TomGranot/hubspot-admin-skills -a claude-code/plugin add https://github.com/TomGranot/hubspot-admin-skillsgit clone https://github.com/TomGranot/hubspot-admin-skills.git ~/.claude/skills/enrich-industry在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
Enrich Contact Industry from Associated Company
Copy industry data from company records to their associated contacts. In a typical B2B CRM, company records have industry populated at high rates (80-90%) while contact records have almost none. This workflow bridges that gap automatically.
Why This Matters
Without industry on contact records, you cannot segment email campaigns by vertical. For B2B companies targeting specific industries, this makes the difference between spray-and-pray email blasts and targeted, relevant messaging. Industry data on contacts also feeds ICP tier classification and lead scoring models.
Prerequisites
- HubSpot Marketing Hub Professional or Sales Hub Professional (for Workflows)
- Company name enrichment (enrich-company-name skill) should be completed first, as it may trigger new company associations
- Access to Settings > Properties to verify/create the contact Industry property
Plan
- Verify the contact Industry property exists and is compatible with the company Industry property
- Audit how many contacts can be enriched (before state)
- Build a workflow that copies industry from the associated company
- Verify enrichment results (after state)
Before State
Check Property Compatibility
This is the most important pre-step. Contacts may have TWO industry properties: industry and industry_name. You must verify which one HubSpot uses for lists and reports.
- Go to Settings > Properties > Contact properties
- Search for "Industry"
- Note ALL industry-related properties on the contact object
- Check which property is used in existing lists, reports, and workflows
- The target property must be compatible with the company Industry property:
- If both are dropdown select: option values must match exactly (same spelling, same case)
- If the contact property is single-line text: it will accept any value (safest option)
- If unsure, use single-line text to avoid copy failures
If no contact Industry property exists, create one:
- Object: Contact
- Group: Contact information
- Label: Industry
- Field type: Dropdown select (copy all values from the company Industry property) OR Single-line text (accepts any value)
Audit Enrichment Opportunity
import os
from hubspot import HubSpot
from dotenv import load_dotenv
load_dotenv()
api_client = HubSpot(access_token=os.getenv("HUBSPOT_API_TOKEN"))
# Count contacts missing industry
result = api_client.crm.contacts.search_api.do_search(
public_object_search_request={
"filterGroups": [{
"filters": [{
"propertyName": "industry",
"operator": "NOT_HAS_PROPERTY"
}]
}],
"limit": 0
}
)
print(f"Contacts missing industry: {result.total}")
Also create a HubSpot list to estimate enrichable contacts:
- Filter 1: Contact Industry > is unknown
- Filter 2: AND Associated company > Industry > is known
- This count tells you how many contacts will actually be enriched
Execute
Create the Enrichment Workflow
This workflow is nearly identical to the company name enrichment workflow. If you already built that one, clone it and swap the property references.
- Go to Automation > Workflows > Create workflow
- Select Contact-based > Blank workflow
- Name:
AUTO-ENRICH: Copy Industry from Company
Enrollment trigger:
- Contact property > Industry > is unknown
- AND Associated company > Industry > is known
Re-enrollment:
- Enable re-enrollment on the same criteria. This ensures contacts that later get associated with a company are also enriched.
Action: Copy property
- Copy FROM: Company > Industry
- Copy TO: Contact > Industry
Activate:
- Click Review > Turn on
- Select Yes, enroll existing contacts
Note: Unlike the company name workflow, no delay is needed here. If the contact already has an associated company with industry data (checked by the enrollment trigger), the copy can happen immediately.
After State
Wait 1-2 hours for the workflow to process, then verify.
Script approach:
result = api_client.crm.contacts.search_api.do_search(
public_object_search_request={
"filterGroups": [{
"filters": [{
"propertyName": "industry",
"operator": "NOT_HAS_PROPERTY"
}]
}],
"limit": 0
}
)
print(f"Contacts still missing industry: {result.total}")
Verification checklist:
- Contact industry count should jump from near-zero to tens of thousands
- The enrichment list (missing industry + has company association) should be near 0
- Spot-check 20+ contacts for accuracy:
- Open the contact record
- Verify the Industry field shows a value
- Click the associated company and confirm the industry matches
- Check that the industry distribution on contacts roughly mirrors the company industry distribution
- Check workflow history for failures — most common is property value mismatch (company has a value that does not match a dropdown option on the contact)
Key Technical Learnings
- Two industry properties can exist. Some HubSpot portals have both
industryandindustry_nameon contacts. Verify which one is authoritative before building the workflow. Writing to the wrong one means your lists and reports will not see the data. - Dropdown value matching is case-sensitive and exact. If the company Industry has "Healthcare" and the contact Industry dropdown has "healthcare" (lowercase), the copy will fail. Ensure values match exactly.
- Consider consolidating similar industries. Many CRMs have overlapping values like "Healthcare" and "Hospital & Health Care". For segmentation, consider creating a separate "Industry Group" property that maps similar values into broader categories. This is optional but improves list usability.
- This does not overwrite existing values. The enrollment trigger requires "Industry is unknown", so contacts that already have industry data are not affected.
- If using a text field instead of dropdown: Enrichment works, but you lose the ability to filter by exact dropdown values in lists. You can convert to a dropdown later but will need to clean up inconsistent text values first.
- Run this after company name enrichment. Company name enrichment may trigger new company associations, which increases the number of contacts eligible for industry enrichment.
- Clone the company name workflow. The structure is nearly identical. Clone it in HubSpot and swap the property references to save time.
GitHub 仓库
相关推荐技能
llamaguard
其他LlamaGuard是Meta推出的7-8B参数内容审核模型,专门用于过滤LLM的输入和输出内容。它能检测六大安全风险类别(暴力/仇恨、性内容、武器、违禁品、自残、犯罪计划),准确率达94-95%。开发者可通过HuggingFace、vLLM或Sagemaker快速部署,并能与NeMo Guardrails集成实现自动化安全防护。
cost-optimization
其他这个Claude Skill帮助开发者优化云成本,通过资源调整、标记策略和预留实例来降低AWS、Azure和GCP的开支。它适用于减少云支出、分析基础设施成本或实施成本治理策略的场景。关键功能包括提供成本可视化、资源规模调整指导和定价模型优化建议。
quantizing-models-bitsandbytes
其他这个Skill使用bitsandbytes库量化大语言模型,能在GPU内存有限时通过8位或4位量化减少50-75%内存占用,同时保持精度损失最小。它支持INT8、NF4、FP4等多种量化格式,可与HuggingFace Transformers无缝集成,适用于需要部署更大模型或加速推理的场景。还提供QLoRA训练和8位优化器支持,让开发者能轻松实现高效模型压缩。
dispatching-parallel-agents
其他该Skill用于并行处理3个以上无依赖关系的独立故障,可为每个问题域分派专属Claude代理同时执行调查修复。它通过并发处理多个独立问题显著提升故障排查效率,特别适用于测试文件、子系统等无共享状态的场景。
