USPTO数据库Skill uspto-database

这个技能用于访问美国专利商标局(USPTO)的API,进行专利和商标数据的搜索、分析、审查历史追踪、所有权转让监控等,支持知识产权分析和先有技术搜索。关键词:USPTO API, 专利搜索, 商标数据, 数据分析, IP分析

数据分析 0 次安装 0 次浏览 更新于 3/16/2026

name: uspto-database description: “访问USPTO API进行专利/商标搜索、审查历史(PEDS)、转让、引用、办公室行动、TSDR,用于IP分析和先有技术搜索。”

USPTO 数据库

概述

USPTO 提供专门的 API 用于专利和商标数据。通过关键词/发明人/受让人搜索专利,通过 PEDS 检索审查历史,跟踪转让,分析引用和办公室行动,访问 TSDR 获取商标数据,用于 IP 分析和先有技术搜索。

何时使用此技能

此技能应在以下情况下使用:

  • 专利搜索:通过关键词、发明人、受让人、分类或日期查找专利
  • 专利详情:检索包括权利要求、摘要、引用在内的完整专利数据
  • 商标搜索:通过序列号或注册号查找商标
  • 商标状态:检查商标状态、所有权和审查历史
  • 审查历史:从 PEDS(专利审查数据系统)访问专利审查数据
  • 办公室行动:检索办公室行动文本、引用和驳回
  • 转让:跟踪专利/商标所有权转移
  • 引用:分析专利引用(前向和后向)
  • 诉讼:访问专利诉讼记录
  • 组合分析:为公司或发明人分析专利/商标组合

USPTO API 生态系统

USPTO 提供多个专门的 API 用于不同的数据需求:

核心 API

  1. PatentSearch API - 基于 ElasticSearch 的现代专利搜索(于 2025 年 5 月取代旧版 PatentsView)

    • 通过关键词、发明人、受让人、分类、日期搜索专利
    • 访问截至 2025 年 6 月 30 日的专利数据
    • 45 次/分钟的速率限制
    • 基础 URLhttps://search.patentsview.org/api/v1/
  2. PEDS(专利审查数据系统) - 专利审查历史

    • 1981 年至今的申请状态和交易历史
    • 办公室行动日期和审查事件
    • 使用 uspto-opendata-python Python 库
    • 已取代:PAIR 批量数据(PBD)- 已停用
  3. TSDR(商标状态和文档检索) - 商标数据

    • 商标状态、所有权、审查历史
    • 通过序列号或注册号搜索
    • 基础 URLhttps://tsdrapi.uspto.gov/ts/cd/

其他 API

  1. 专利转让搜索 - 所有权记录和转移
  2. 商标转让搜索 - 商标所有权变更
  3. 丰富引用 API - 专利引用分析
  4. 办公室行动文本检索 - 办公室行动完整文本
  5. 办公室行动引用 - 办公室行动中的引用
  6. 办公室行动驳回 - 驳回原因和类型
  7. PTAB API - 专利审判和上诉委员会程序
  8. 专利诉讼案件 - 联邦地区法院诉讼数据
  9. 癌症登月数据集 - 癌症相关专利

快速开始

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

基础 URLhttps://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

最佳实践

  1. API 密钥管理

    • 将 API 密钥存储在环境变量中
    • 切勿将密钥提交到版本控制
    • 在所有 USPTO API 中使用相同的密钥
  2. 速率限制

    • PatentSearch:45 次/分钟
    • 实现指数退避以处理速率限制错误
    • 尽可能缓存响应
  3. 查询优化

    • 对文本字段使用 _text_* 运算符(更高效)
    • 仅请求所需字段以减少响应大小
    • 使用日期范围缩小搜索范围
  4. 数据处理

    • 并非所有字段都填充所有专利/商标
    • 优雅处理缺失数据
    • 一致解析日期
  5. 组合 API

    • 使用 PatentSearch 进行发现
    • 使用 PEDS 获取审查详情
    • 使用转让 API 进行所有权跟踪
    • 结合数据进行综合分析

重要注意事项

  • 旧版 API 停用:PatentsView 旧版 API 于 2025 年 5 月 1 日停用 - 使用 PatentSearch API
  • PAIR 批量数据停用:使用 PEDS 代替
  • 数据覆盖:PatentSearch 数据截至 2025 年 6 月 30 日;PEDS 从 1981 年至今
  • 文本端点:权利要求和描述端点为测试版,正在持续填充
  • 速率限制:遵守速率限制以避免服务中断

资源

API 文档

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 - 商标搜索客户端