找回密码
 立即注册
查看: 915|回复: 0

美国专利局1秒限1次请求,爬虫工程师用这招绕过

[复制链接]

62

主题

28

回帖

279

积分

中级会员

积分
279
发表于 2026-3-27 17:35:26 | 显示全部楼层 |阅读模式
SdBycHdE44thdpNZ.jpg 5 J. X5 T1 ^7 M; }. U. N8 f
% n9 Y6 C! D& c# F! f* V
美国专利商标局(USPTO)的开放数据接口每秒只允许1次请求,欧洲专利局(EPO)强制OAuth 2.0认证,Google Patents干脆用JavaScript动态渲染——三家主流专利数据库,三种完全不同的反爬策略。一位做竞争情报的产品经理算过账:手动检索5000条专利信息,熟练工需要40小时;写个靠谱的爬虫,2小时搭建,10分钟跑完。2 f# g, J; \' U* h7 u
专利数据的价值被严重低估。药企追踪竞争对手的化合物专利布局,硬科技公司监控标准必要专利(SEP)的授权动态,投资机构用专利引用网络预测技术并购标的。这些信息全部公开,但分散在三个体系、五种格式、无数分页里。
  d# q1 `5 Z# B6 w本文提供可直接运行的代码框架,覆盖USPTO、EPO、Google Patents三大数据源。不需要你懂自然语言处理,不需要部署分布式集群,一台笔记本就能启动。
3 D* _, W4 B/ S: e. `$ w; \5 i' ?, R/ W
USPTO:官方API的"绅士协议"
, h. e: {4 @; C) i5 q1 U2 |+ c1 q; z, ]* O# W1 L  n6 @
# ?, \% U( G, q' S2 x% R
美国专利商标局算是态度最友好的。他们提供RESTful API,文档完整,甚至不用注册就能调用。但有个隐性规则:官方建议每秒不超过1次请求。这不是技术限制,是写在服务条款里的"绅士协议"。( m* O- h2 {2 x. A: A* O" n7 x
违反的后果很实在——IP进黑名单,24小时解封。对于需要批量获取的用户,这个限速意味着检索10万条专利需要27小时以上。! b, h# J3 ]" ^3 a
解决方案藏在请求节奏里。下面这个类封装了自动延迟和分页逻辑:4 V/ a( m& W" V
核心设计:用time.sleep(self.delay)强制节流,用Session复用TCP连接减少握手开销。/ w- z' I0 W/ E0 e4 @+ Z
代码里的search_all方法实现了"懒加载"式分页——不预设总页数,拿到空结果就停。这种设计对USPTO特别重要,因为他们的搜索结果集大小不固定,last-modified-date字段可能让同一查询返回不同数量的记录。
' }3 `: U$ o* \3 W7 o! m6 M一个细节:USPTO的返回字段命名极其美式。inventionTitle是发明名称,firstNamedApplicant是第一申请人,publicationDate用YYYYMMDD字符串而非时间戳。做数据清洗时记得统一格式,否则下游分析会踩坑。
3 \  l- O2 h2 y- f! R# n' Z' D0 @9 F实际跑测,查询"artificial intelligence"返回的50条记录中,有3条的inventionTitle字段为空。USPTO的数据质量并非完美,空值处理必须写进生产代码。
& O5 D3 z; p1 I$ B5 P: Z! g, Z0 D! m( s
EPO:OAuth 2.0的"欧洲式严谨"
! D2 F6 P  P  m) u; z- M0 M1 {) D! @% Y! }* r" V% ]

6 L! H7 h  H: h欧洲专利局的API门槛明显更高。强制要求注册获取consumer_key和consumer_secret,采用OAuth 2.0的客户端凭证模式(Client Credentials Grant)。每次调用前要先拿access_token,token有效期10分钟。0 @- W1 H2 w- x1 u" Y* Q  o
这个设计增加了代码复杂度,但换来了更精细的配额管理。EPO给每个注册应用分配每日调用额度,付费 tier 可以提升到10万次/天。对于中小企业,免费额度通常够用。( X* B5 c& j7 t+ _3 H
认证流程需要Base64编码的凭证组合:
9 K+ x  J$ p: A$ s7 E% l, U' `关键点:EPO的Range参数用"begin-end"的闭区间格式,和USPTO的start+rows逻辑不同。混用会导致数据重复或遗漏。
" s. z" d  y/ j5 d4 \8 }另一个坑是数据格式。EPO返回的XML/JSON混合了多种专利文献标准,同一条专利可能有多个publication-number(申请号、公开号、授权号)。做去重时建议用docdb格式的唯一标识符,而非直观的专利号字符串。
/ w% I% ]9 Q! w  Y1 X实测发现EPO的搜索语法更接近传统检索系统。支持通配符(*)、邻近算符(near/within)、分类号前缀匹配。对于需要复杂检索式的场景,EPO的表达能力比USPTO强一个量级。( I- R1 k& L  W  o2 _0 s1 Q2 X1 {. o

( ^0 o* S% {1 c3 a/ I/ DGoogle Patents:动态渲染的"猫鼠游戏"/ j' W: U. y  u
/ R, y2 l; I$ m1 v

/ l* a, K7 w8 oGoogle Patents没有官方API。这个聚合平台从USPTO、EPO、WIPO等数十个来源抓取数据,做语义增强和机器翻译,然后以免费搜索的形式呈现。数据最全,反爬也最严。
1 M$ a5 N" {  a  f1 Z直接请求HTML会拿到骨架页面,专利详情藏在JavaScript渲染后的DOM里。传统requests库束手无策,必须上浏览器自动化工具。
7 i+ s+ m! o* R, c1 \& KPlaywright是目前的最优解。相比Selenium,它的定位更精准,等待机制更可靠,对现代前端框架(React/Vue)的兼容性更好。
4 H7 r* o$ r1 p! }/ o基础架构:用sync_playwright启动Chromium,设置viewport和user-agent模拟真实用户,等待networkidle确保动态内容加载完成。
1 T' E  m1 n% _5 q8 v& M1 U反反爬的关键细节:headless=False能降低检测概率,但牺牲性能;route方法拦截图片和字体请求,减少80%以上的带宽消耗;page.wait_for_selector确保目标元素出现后再提取,避免竞态条件。) I5 n9 k* i8 N+ H/ w" K
Google Patents的页面结构经常微调。2024年3月的一次更新把专利标题从h1.item-title改成了span[data-target="title"],导致大量旧爬虫失效。生产环境建议用相对稳定的文本特征定位,比如包含"Patent"的meta标签,而非硬编码CSS选择器。8 N1 }: I) c) W
数据提取后会发现,Google做了大量衍生计算。同族专利聚合、引用网络可视化、法律状态时间线——这些增值信息在原始专利数据库里分散在多张表,Google帮你JOIN好了。代价是字段命名完全不遵循任何标准,需要额外映射层。
* b+ c9 ?; o9 k' ?4 ?) f; X
# U. W# k: Z, ~8 S3 T, j三种策略的选型决策树: o$ p* ]* d! o/ A
3 d* S7 X% P8 ]' d4 J1 n- T( J
) M4 {1 {& f, L; p! k& m
USPTO适合快速原型和美式专利追踪,代码最简单,数据最原始。缺点是仅限美国申请,且2015年前的专利数据格式混乱(从SGML迁移遗留的问题)。8 T! k! E$ B: o3 \" R- @' j
EPO适合需要复杂检索和全球覆盖的场景。OAuth流程增加了初期成本,但数据规范性和多语言支持最好。特别注意:EPO的OPS API不包含全文文本,只有摘要和权利要求,全文需要额外调用其他服务。: u- {& N$ n" |1 m9 m0 G2 Y( h
Google Patents适合需要"开箱即用"的聚合数据,尤其是引用分析和同族专利映射。反爬对抗是持续成本,适合有运维资源的中长期项目。1 B* b9 e$ ]; j7 u" A
一个混合策略:用USPTO/EPO的官方API获取基础元数据,用Google Patents补充引用关系和语义标签。两者通过公开号(publication number)关联,匹配率通常在95%以上。
6 J) \' J3 O! W7 Z: Y( f性能基准:在同一台MacBook Pro M3上,USPTO爬虫跑1000条记录耗时18分钟(受限于1秒延迟),EPO耗时12分钟(网络延迟更低),Google Patents用Playwright耗时47分钟(浏览器开销)。如果Google解除反爬,纯HTTP请求能把时间压到3分钟以内——但这不会发生。
" w; X1 S* c. ~: o* r法律风险提示:三家平台的robots.txt和服务条款对爬虫态度不一。USPTO明确允许"reasonable automated access",EPO要求"non-commercial use or commercial license",Google Patents的Terms of Service禁止"automated means"访问。实际执行中,控制请求频率、不干扰正常服务、仅用于内部分析,通常不会触发法律行动。但大规模商业部署前,建议咨询知识产权律师。7 J  m( j3 x& d! K& c
最后放一段读者反馈。上周把USPTO的代码片段发给一位做医药情报的朋友,他当天下午就改出了监控特定IPC分类号(C07D/杂环化合物)的预警脚本。"以前每周花6小时刷EPO的检索式,现在每天早上收邮件就行。"
集群智慧云科服专利申请服务
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则


快速回复 返回顶部 返回列表