Python爬虫入门:requests使用教程详解
时间:2026-03-08 23:42:26 498浏览 收藏
本文系统介绍了Python爬虫入门必备的requests库,从零开始讲解如何用三行代码轻松获取网页内容,并深入剖析带参数请求、伪装请求头绕过基础反爬、智能解析JSON与HTML响应、以及通过异常处理和Session会话保持提升爬虫稳定性与实用性——无论你是编程新手还是想夯实爬虫基础的开发者,掌握这些核心技巧,就能高效、可靠地完成绝大多数静态页面抓取任务。

想用 Python 写爬虫,requests 是最该先掌握的库——它简单、稳定、功能够用,90% 的静态页面抓取任务靠它就能搞定。
一、安装和基础请求:三行代码拿下网页
先确保已安装 requests(没装就运行 pip install requests)。然后:
- 用 requests.get(url) 发起 GET 请求,返回一个 Response 对象
- 用 .text 获取字符串内容(适合 HTML、JSON 文本)
- 用 .content 获取原始字节(适合图片、PDF 等二进制数据)
示例:
import requests
res = requests.get('https://httpbin.org/get')
print(res.status_code) # 看状态码,200 表示成功
print(res.text) # 打印响应正文
二、带参数和请求头:让请求更像真人
很多网站会检查 User-Agent,直接请求可能被拒绝或返回 403。加上 headers 就能绕过基础反爬:
- URL 参数用 params=字典 自动拼接(比手动拼 '?a=1&b=2' 更安全)
- 请求头用 headers=字典,常见字段如 'User-Agent'、'Referer'
示例:
url = 'https://httpbin.org/get'
params = {'page': 1, 'limit': 10}
headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36'}
res = requests.get(url, params=params, headers=headers)
三、处理响应数据:提取关键信息不靠猜
拿到响应后,别急着正则或手撕 HTML。先判断类型再选工具:
- 如果返回的是 JSON(比如接口),直接用 res.json() 解析成 Python 字典
- 如果是 HTML,推荐后续配合 BeautifulSoup 或 lxml 解析结构化数据
- 注意检查 res.encoding,中文乱码时可手动设为 'utf-8' 或 'gbk'
示例(解析 JSON 接口):
res = requests.get('https://httpbin.org/json')
data = res.json() # 自动解析,不用 json.loads(res.text)
print(data['slideshow']['title']) # 直接按键取值
四、异常处理和会话保持:让爬虫稳一点
真实环境中网络不稳定、目标站改版、超时都是常态,加一层防护很必要:
- 用 try-except 捕获 requests.exceptions.RequestException(含超时、连接失败等)
- 设置 timeout=(连接超时, 读取超时),避免卡死,比如 timeout=(3, 10)
- 需要登录或保持 Cookie 时,用 requests.Session() 替代 get/post,自动管理会话
示例(带超时和会话):
session = requests.Session()
session.headers.update({'User-Agent': 'xxx'})
<p>try:
res = session.get('<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyero6Kn83GjHPXkraZo5qYYKbEeWmixpBsmnmyhqKulbikgnae3LJ7hpmGqrWyhbqUmbuseWm0faNkio2Ga77ds7KOho3PsqF-mQ' rel='nofollow'>https://example.com/login</a>', timeout=(3, 10))
res.raise_for_status() # 非2xx状态码抛异常
except requests.exceptions.RequestException as e:
print("请求失败:", e)
</p>文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Python爬虫入门:requests使用教程详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
447 收藏
-
133 收藏
-
121 收藏
-
423 收藏
-
394 收藏
-
314 收藏
-
232 收藏
-
434 收藏
-
123 收藏
-
494 收藏
-
319 收藏
-
194 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习