如何设置爬虫的延时避免被封禁

在使用爬虫获取数据时,合理设置延时是避免被目标网站封禁的关键策略之一。以下是一些常见的方法和技巧:

一、使用 time.sleep() 设置固定延时

time.sleep() 是 Python 中最常用的延时方法,可以在每次请求之间设置固定的延时,从而降低请求频率。

Python

python 复制代码
import time
import requests

headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36"
}

urls = ["http://example.com/page1", "http://example.com/page2"]  # 示例URL列表

for url in urls:
    response = requests.get(url, headers=headers)
    time.sleep(1)  # 每次请求间隔1秒

二、使用随机延时

为了更好地模拟真实用户的行为,可以设置随机延时。这可以通过 random.uniform()random.randint() 实现。

Python

python 复制代码
import time
import random
import requests

headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36"
}

urls = ["http://example.com/page1", "http://example.com/page2"]  # 示例URL列表

for url in urls:
    response = requests.get(url, headers=headers)
    delay = random.uniform(0.5, 2.0)  # 随机延时0.5到2秒
    time.sleep(delay)

三、使用 Scrapy 框架的 DOWNLOAD_DELAY 设置延时

如果你使用的是 Scrapy 框架,可以通过设置 DOWNLOAD_DELAY 来控制请求间隔。

Python

python 复制代码
# 在 settings.py 中设置
DOWNLOAD_DELAY = 2  # 每次请求间隔2秒

此外,还可以结合 RandomDelayMiddleware 实现随机延时。

四、使用代理服务器

使用代理服务器可以隐藏真实 IP 地址,降低被封禁的风险。可以结合 requests 库使用代理。

Python

python 复制代码
import requests
import random

proxy_list = [
    {"http": "http://proxy1.example.com:8080"},
    {"http": "http://proxy2.example.com:8080"},
]

url = "http://example.com/data"

for _ in range(5):  # 示例:发送5次请求
    proxy = random.choice(proxy_list)
    response = requests.get(url, proxies=proxy)
    time.sleep(1)  # 每次请求间隔1秒

五、结合其他策略

除了设置延时,还可以结合其他策略来降低被封禁的风险:

  • 随机更换 User-Agent:模拟不同的浏览器访问。

  • 遵守 robots.txt 文件:遵循目标网站的爬取规则。

  • 使用会话和 Cookies:模拟真实用户的浏览行为。

六、总结

合理设置延时是避免爬虫被封禁的重要策略。通过使用 time.sleep() 设置固定延时、使用随机延时、结合 Scrapy 框架的 DOWNLOAD_DELAY、使用代理服务器以及结合其他策略,可以有效降低爬虫被封禁的风险。在实际应用中,建议根据目标网站的实际情况灵活调整延时策略。

相关推荐
胡耀超4 小时前
Web Crawling 网络爬虫全景:技术体系、反爬对抗与全链路成本分析
前端·爬虫·python·网络爬虫·数据采集·逆向工程·反爬虫
itjinyin4 小时前
初级爬虫实战——巴黎圣母院新闻
爬虫
vx_biyesheji00017 小时前
计算机毕业设计:Python多源新闻数据智能舆情挖掘平台 Flask框架 爬虫 SnowNLP ARIMA 可视化 数据分析 大数据(建议收藏)✅
爬虫·python·机器学习·数据分析·django·flask·课程设计
j_xxx404_8 小时前
爬虫对抗:ZLibrary反爬机制实战分析 (三) - 突破高频访问限制与TLS指纹(JA3)风控
爬虫
16Miku8 小时前
Mapping-Skill:把 AI/ML 人才搜索、作者挖掘与个性化触达整合成一条工作流
爬虫·ai·飞书·agent·skill·openclaw·龙虾
j_xxx404_9 小时前
爬虫对抗:ZLibrary反爬机制实战分析 (一) - 撕裂前端JS混淆与环境检测伪装
爬虫
小邓睡不饱耶10 小时前
东方财富网股票数据爬取实战:从接口分析到数据存储
开发语言·爬虫·python·网络爬虫
Pioneer0000110 小时前
爬虫对抗:ZLibrary反爬机制实战分析
爬虫
j_xxx404_10 小时前
爬虫对抗:ZLibrary反爬机制实战分析 (二) - 破解动态请求签名与参数加密
爬虫
vx_biyesheji000111 小时前
计算机毕业设计:Python全栈图书数据挖掘与可视化看板 Django框架 爬虫 当当图书 Pandas 可视化 大数据 大模型 书籍(建议收藏)✅
爬虫·python·机器学习·数据挖掘·django·毕业设计·课程设计