name: uspto-database description: “访问USPTO API进行专利/商标搜索、审查历史(PEDS)、转让、引用、办公室行动、TSDR,用于IP分析和先有技术搜索。”
USPTO 数据库
概述
USPTO 提供专门的 API 用于专利和商标数据。通过关键词/发明人/受让人搜索专利,通过 PEDS 检索审查历史,跟踪转让,分析引用和办公室行动,访问 TSDR 获取商标数据,用于 IP 分析和先有技术搜索。
何时使用此技能
此技能应在以下情况下使用:
- 专利搜索:通过关键词、发明人、受让人、分类或日期查找专利
- 专利详情:检索包括权利要求、摘要、引用在内的完整专利数据
- 商标搜索:通过序列号或注册号查找商标
- 商标状态:检查商标状态、所有权和审查历史
- 审查历史:从 PEDS(专利审查数据系统)访问专利审查数据
- 办公室行动:检索办公室行动文本、引用和驳回
- 转让:跟踪专利/商标所有权转移
- 引用:分析专利引用(前向和后向)
- 诉讼:访问专利诉讼记录
- 组合分析:为公司或发明人分析专利/商标组合
USPTO API 生态系统
USPTO 提供多个专门的 API 用于不同的数据需求:
核心 API
-
PatentSearch API - 基于 ElasticSearch 的现代专利搜索(于 2025 年 5 月取代旧版 PatentsView)
- 通过关键词、发明人、受让人、分类、日期搜索专利
- 访问截至 2025 年 6 月 30 日的专利数据
- 45 次/分钟的速率限制
- 基础 URL:
https://search.patentsview.org/api/v1/
-
PEDS(专利审查数据系统) - 专利审查历史
- 1981 年至今的申请状态和交易历史
- 办公室行动日期和审查事件
- 使用
uspto-opendata-pythonPython 库 - 已取代:PAIR 批量数据(PBD)- 已停用
-
TSDR(商标状态和文档检索) - 商标数据
- 商标状态、所有权、审查历史
- 通过序列号或注册号搜索
- 基础 URL:
https://tsdrapi.uspto.gov/ts/cd/
其他 API
- 专利转让搜索 - 所有权记录和转移
- 商标转让搜索 - 商标所有权变更
- 丰富引用 API - 专利引用分析
- 办公室行动文本检索 - 办公室行动完整文本
- 办公室行动引用 - 办公室行动中的引用
- 办公室行动驳回 - 驳回原因和类型
- PTAB API - 专利审判和上诉委员会程序
- 专利诉讼案件 - 联邦地区法院诉讼数据
- 癌症登月数据集 - 癌症相关专利
快速开始
API 密钥注册
所有 USPTO API 都需要 API 密钥。在以下网址注册: https://account.uspto.gov/api-manager/
将 API 密钥设置为环境变量:
export USPTO_API_KEY="your_api_key_here"
帮助脚本
此技能包含用于常见操作的 Python 脚本:
scripts/patent_search.py- PatentSearch API 客户端,用于搜索专利scripts/peds_client.py- PEDS 客户端,用于审查历史scripts/trademark_client.py- TSDR 客户端,用于商标数据
任务 1:搜索专利
使用 PatentSearch API
PatentSearch API 使用 JSON 查询语言,具有各种运算符,实现灵活搜索。
基础专利搜索示例
通过摘要中的关键词搜索:
from scripts.patent_search import PatentSearchClient
client = PatentSearchClient()
# 搜索机器学习专利
results = client.search_patents({
"patent_abstract": {"_text_all": ["machine", "learning"]}
})
for patent in results['patents']:
print(f"{patent['patent_number']}: {patent['patent_title']}")
通过发明人搜索:
results = client.search_by_inventor("John Smith")
通过受让人/公司搜索:
results = client.search_by_assignee("Google")
通过日期范围搜索:
results = client.search_by_date_range("2024-01-01", "2024-12-31")
通过 CPC 分类搜索:
results = client.search_by_classification("H04N") # 视频/图像技术
高级专利搜索
使用逻辑运算符组合多个条件:
results = client.advanced_search(
keywords=["artificial", "intelligence"],
assignee="Microsoft",
start_date="2023-01-01",
end_date="2024-12-31",
cpc_codes=["G06N", "G06F"] # AI 和计算分类
)
直接 API 使用
对于复杂查询,直接使用 API:
import requests
url = "https://search.patentsview.org/api/v1/patent"
headers = {
"X-Api-Key": "YOUR_API_KEY",
"Content-Type": "application/json"
}
query = {
"q": {
"_and": [
{"patent_date": {"_gte": "2024-01-01"}},
{"assignee_organization": {"_text_any": ["Google", "Alphabet"]}},
{"cpc_subclass_id": ["G06N", "H04N"]}
]
},
"f": ["patent_number", "patent_title", "patent_date", "inventor_name"],
"s": [{"patent_date": "desc"}],
"o": {"per_page": 100, "page": 1}
}
response = requests.post(url, headers=headers, json=query)
results = response.json()
查询运算符
- 相等性:
{"field": "value"}或{"field": {"_eq": "value"}} - 比较:
_gt,_gte,_lt,_lte,_neq - 文本搜索:
_text_all,_text_any,_text_phrase - 字符串匹配:
_begins,_contains - 逻辑:
_and,_or,_not
最佳实践:对文本字段使用 _text_* 运算符(比 _contains 或 _begins 更高效)
可用专利端点
/patent- 授权专利/publication- 预授权出版物/inventor- 发明人信息/assignee- 受让人信息/cpc_subclass,/cpc_at_issue- CPC 分类/uspc- 美国专利分类/ipc- 国际专利分类/claims,/brief_summary_text,/detail_description_text- 文本数据(测试版)
参考文档
参见 references/patentsearch_api.md 获取完整的 PatentSearch API 文档,包括:
- 所有可用端点
- 完整字段参考
- 查询语法和示例
- 响应格式
- 速率限制和最佳实践
任务 2:检索专利审查数据
使用 PEDS(专利审查数据系统)
PEDS 提供全面的审查历史,包括交易事件、状态变更和审查时间线。
安装
pip install uspto-opendata-python
基础 PEDS 使用
获取申请数据:
from scripts.peds_client import PEDSHelper
helper = PEDSHelper()
# 通过申请号
app_data = helper.get_application("16123456")
print(f"Title: {app_data['title']}")
print(f"Status: {app_data['app_status']}")
# 通过专利号
patent_data = helper.get_patent("11234567")
获取交易历史:
transactions = helper.get_transaction_history("16123456")
for trans in transactions:
print(f"{trans['date']}: {trans['code']} - {trans['description']}")
获取办公室行动:
office_actions = helper.get_office_actions("16123456")
for oa in office_actions:
if oa['code'] == 'CTNF':
print(f"非最终驳回: {oa['date']}")
elif oa['code'] == 'CTFR':
print(f"最终驳回: {oa['date']}")
elif oa['code'] == 'NOA':
print(f"允许通知: {oa['date']}")
获取状态摘要:
summary = helper.get_status_summary("16123456")
print(f"当前状态: {summary['current_status']}")
print(f"申请日期: {summary['filing_date']}")
print(f"待审期: {summary['pendency_days']} 天")
if summary['is_patented']:
print(f"专利号: {summary['patent_number']}")
print(f"授权日期: {summary['issue_date']}")
审查分析
分析审查模式:
analysis = helper.analyze_prosecution("16123456")
print(f"总办公室行动: {analysis['total_office_actions']}")
print(f"非最终驳回: {analysis['non_final_rejections']}")
print(f"最终驳回: {analysis['final_rejections']}")
print(f"允许: {analysis['allowance']}")
print(f"提交的响应: {analysis['responses']}")
常见交易代码
- CTNF - 非最终驳回邮寄
- CTFR - 最终驳回邮寄
- NOA - 允许通知邮寄
- WRIT - 响应提交
- ISS.FEE - 授权费支付
- ABND - 申请放弃
- AOPF - 办公室行动邮寄
参考文档
参见 references/peds_api.md 获取完整的 PEDS 文档,包括:
- 所有可用数据字段
- 交易代码参考
- Python 库使用
- 组合分析示例
任务 3:搜索和监控商标
使用 TSDR(商标状态和文档检索)
访问商标状态、所有权和审查历史。
基础商标使用
通过序列号获取商标:
from scripts.trademark_client import TrademarkClient
client = TrademarkClient()
# 通过序列号
tm_data = client.get_trademark_by_serial("87654321")
# 通过注册号
tm_data = client.get_trademark_by_registration("5678901")
获取商标状态:
status = client.get_trademark_status("87654321")
print(f"标记: {status['mark_text']}")
print(f"状态: {status['status']}")
print(f"申请日期: {status['filing_date']}")
if status['is_registered']:
print(f"注册号: {status['registration_number']}")
print(f"注册日期: {status['registration_date']}")
检查商标健康度:
health = client.check_trademark_health("87654321")
print(f"标记: {health['mark']}")
print(f"状态: {health['status']}")
for alert in health['alerts']:
print(alert)
if health['needs_attention']:
print("⚠️ 此标记需要注意!")
商标组合监控
监控多个商标:
def monitor_portfolio(serial_numbers, api_key):
"""监控商标组合健康度。"""
client = TrademarkClient(api_key)
results = {
'active': [],
'pending': [],
'problems': []
}
for sn in serial_numbers:
health = client.check_trademark_health(sn)
if 'REGISTERED' in health['status']:
results['active'].append(health)
elif 'PENDING' in health['status'] or 'PUBLISHED' in health['status']:
results['pending'].append(health)
elif health['needs_attention']:
results['problems'].append(health)
return results
常见商标状态
- REGISTERED - 活跃注册标记
- PENDING - 审查中
- PUBLISHED FOR OPPOSITION - 异议期
- ABANDONED - 申请放弃
- CANCELLED - 注册取消
- SUSPENDED - 审查暂停
- REGISTERED AND RENEWED - 注册续展
参考文档
参见 references/trademark_api.md 获取完整的商标 API 文档,包括:
- TSDR API 参考
- 商标转让搜索 API
- 所有状态代码
- 审查历史访问
- 所有权跟踪
任务 4:跟踪转让和所有权
专利和商标转让
专利和商标都有转让搜索 API 用于跟踪所有权变更。
专利转让 API
基础 URL:https://assignment-api.uspto.gov/patent/v1.4/
通过专利号搜索:
import requests
import xml.etree.ElementTree as ET
def get_patent_assignments(patent_number, api_key):
url = f"https://assignment-api.uspto.gov/patent/v1.4/assignment/patent/{patent_number}"
headers = {"X-Api-Key": api_key}
response = requests.get(url, headers=headers)
if response.status_code == 200:
return response.text # 返回 XML
assignments_xml = get_patent_assignments("11234567", api_key)
root = ET.fromstring(assignments_xml)
for assignment in root.findall('.//assignment'):
recorded_date = assignment.find('recordedDate').text
assignor = assignment.find('.//assignor/name').text
assignee = assignment.find('.//assignee/name').text
conveyance = assignment.find('conveyanceText').text
print(f"{recorded_date}: {assignor} → {assignee}")
print(f" 类型: {conveyance}
")
通过公司名称搜索:
def find_company_patents(company_name, api_key):
url = "https://assignment-api.uspto.gov/patent/v1.4/assignment/search"
headers = {"X-Api-Key": api_key}
data = {"criteria": {"assigneeName": company_name}}
response = requests.post(url, headers=headers, json=data)
return response.text
常见转让类型
- ASSIGNMENT OF ASSIGNORS INTEREST - 所有权转移
- SECURITY AGREEMENT - 担保协议/担保权益
- MERGER - 公司合并
- CHANGE OF NAME - 名称变更
- ASSIGNMENT OF PARTIAL INTEREST - 部分所有权
任务 5:访问其他 USPTO 数据
办公室行动、引用和诉讼
多个专门的 API 提供额外的专利数据。
办公室行动文本检索
使用申请号检索办公室行动的完整文本。与 PEDS 集成,识别存在的办公室行动,然后检索完整文本。
丰富引用 API
分析专利引用:
- 前向引用(引用此专利的专利)
- 后向引用(引用的现有技术)
- 审查员 vs. 申请人引用
- 引用上下文
专利诉讼案件 API
访问联邦地区法院专利诉讼记录:
- 74,623+ 诉讼记录
- 主张的专利
- 当事人和地点
- 案件结果
PTAB API
专利审判和上诉委员会程序:
- 双方复审(IPR)
- 授权后复审(PGR)
- 上诉决定
参考文档
参见 references/additional_apis.md 获取综合文档,包括:
- 丰富引用 API
- 办公室行动 API(文本、引用、驳回)
- 专利诉讼案件 API
- PTAB API
- 癌症登月数据集
- OCE 状态/事件代码
完整分析示例
综合专利分析
结合多个 API 进行完整的专利情报:
def comprehensive_patent_analysis(patent_number, api_key):
"""
使用多个 USPTO API 进行完整专利分析。
"""
from scripts.patent_search import PatentSearchClient
from scripts.peds_client import PEDSHelper
results = {}
# 1. 获取专利详情
patent_client = PatentSearchClient(api_key)
patent_data = patent_client.get_patent(patent_number)
results['patent'] = patent_data
# 2. 获取审查历史
peds = PEDSHelper()
results['prosecution'] = peds.analyze_prosecution(patent_number)
results['status'] = peds.get_status_summary(patent_number)
# 3. 获取转让历史
import requests
assign_url = f"https://assignment-api.uspto.gov/patent/v1.4/assignment/patent/{patent_number}"
assign_resp = requests.get(assign_url, headers={"X-Api-Key": api_key})
results['assignments'] = assign_resp.text if assign_resp.status_code == 200 else None
# 4. 分析结果
print(f"
=== 专利 {patent_number} 分析 ===
")
print(f"标题: {patent_data['patent_title']}")
print(f"受让人: {', '.join(patent_data.get('assignee_organization', []))}")
print(f"授权日期: {patent_data['patent_date']}")
print(f"
审查:")
print(f" 办公室行动: {results['prosecution']['total_office_actions']}")
print(f" 驳回: {results['prosecution']['non_final_rejections']} 非最终, {results['prosecution']['final_rejections']} 最终")
print(f" 待审期: {results['prosecution']['pendency_days']} 天")
# 分析引用
if 'cited_patent_number' in patent_data:
print(f"
引用:")
print(f" 引用: {len(patent_data['cited_patent_number'])} 专利")
if 'citedby_patent_number' in patent_data:
print(f" 被引用: {len(patent_data['citedby_patent_number'])} 专利")
return results
最佳实践
-
API 密钥管理
- 将 API 密钥存储在环境变量中
- 切勿将密钥提交到版本控制
- 在所有 USPTO API 中使用相同的密钥
-
速率限制
- PatentSearch:45 次/分钟
- 实现指数退避以处理速率限制错误
- 尽可能缓存响应
-
查询优化
- 对文本字段使用
_text_*运算符(更高效) - 仅请求所需字段以减少响应大小
- 使用日期范围缩小搜索范围
- 对文本字段使用
-
数据处理
- 并非所有字段都填充所有专利/商标
- 优雅处理缺失数据
- 一致解析日期
-
组合 API
- 使用 PatentSearch 进行发现
- 使用 PEDS 获取审查详情
- 使用转让 API 进行所有权跟踪
- 结合数据进行综合分析
重要注意事项
- 旧版 API 停用:PatentsView 旧版 API 于 2025 年 5 月 1 日停用 - 使用 PatentSearch API
- PAIR 批量数据停用:使用 PEDS 代替
- 数据覆盖:PatentSearch 数据截至 2025 年 6 月 30 日;PEDS 从 1981 年至今
- 文本端点:权利要求和描述端点为测试版,正在持续填充
- 速率限制:遵守速率限制以避免服务中断
资源
API 文档
- PatentSearch API:https://search.patentsview.org/docs/
- USPTO 开发者门户:https://developer.uspto.gov/
- USPTO 开放数据门户:https://data.uspto.gov/
- API 密钥注册:https://account.uspto.gov/api-manager/
Python 库
- uspto-opendata-python:https://pypi.org/project/uspto-opendata-python/
- USPTO 文档:https://docs.ip-tools.org/uspto-opendata-python/
参考文件
references/patentsearch_api.md- 完整的 PatentSearch API 参考references/peds_api.md- PEDS API 和库文档references/trademark_api.md- 商标 API(TSDR 和转让)references/additional_apis.md- 引用、办公室行动、诉讼、PTAB
脚本
scripts/patent_search.py- PatentSearch API 客户端scripts/peds_client.py- PEDS 审查数据客户端scripts/trademark_client.py- 商标搜索客户端