登录
首页 >  文章 >  python教程

Pythonrequests库使用教程

时间:2026-03-15 16:17:34 409浏览 收藏

本文深入浅出地讲解了 Python requests 库的核心实战技巧,涵盖从基础三步(导入、请求、取数)到高级应用的完整链条:包括 GET/POST 请求的规范写法、安全传参与 JSON 自动序列化、文件上传、自定义请求头(如 User-Agent)、会话管理(Session)维持登录态,以及关键的异常处理与精细化超时控制;通过简洁对比 urllib 突出其易用性,又以真实代码示例揭示那些看似简单却极易踩坑的细节——正是这些“不起眼”的设置,决定了网络请求是否稳定、健壮、贴近真实浏览器行为,堪称 Python 爬虫与 API 开发者不可或缺的实用指南。

Python网络请求怎么写_requests库实战教程

requests 发起网络请求,核心就三步:导入库、发请求、取数据。它比原生 urllib 简洁得多,是 Python 网络爬虫和 API 调用的标配。

GET 请求:获取网页或 API 数据

最常用的是 requests.get()。比如抓取一个公开 JSON 接口:

import requests
<p>response = requests.get("<a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyerpV6iZXHe3vUmsyZr5vTk6a8ZIZktWttmJKQjnG-ut6ojWSM0r2LYtuHlaqtm6qkmLxkhW2yo42aebKGoq6VuKSCdp7csnuGmYaqtbKFupSZu6x5abR9o2SKjYZrvt2zso6Gjc-yoX6Z' rel='nofollow'>https://httpbin.org/get?name=alice&amp;age=25</a>")
if response.status_code == 200:
data = response.json()  # 自动解析 JSON
print(data["args"])  # {'name': 'alice', 'age': '25'}
</p>
  • 记得检查 response.status_code,200 表示成功,4xx/5xx 是错误
  • response.text 拿字符串,response.json() 拿字典(自动解析),response.content 拿原始字节(适合图片、PDF)
  • URL 中的参数可用 params 参数传,更安全清晰:requests.get(url, params={"name": "alice", "age": 25})

POST 请求:提交表单或调用接口

向服务器发送数据,常见于登录、上传、调用 REST API:

data = {"username": "test", "password": "123456"}
response = requests.post("https://httpbin.org/post", data=data)
print(response.json()["form"])  # {'username': 'test', 'password': '123456'}
  • data= 发送表单格式(application/x-www-form-urlencoded
  • json= 自动序列化并设好 Content-Type: application/jsonrequests.post(url, json={"key": "value"})
  • 上传文件用 files= 参数:files={"file": open("a.txt", "rb")}

带请求头和会话管理:模拟真实浏览器

很多网站会检查 User-Agent,直接请求可能被拒绝:

headers = {
    "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36"
}
response = requests.get("https://example.com", headers=headers)
  • 常用头还包括 RefererCookieAccept
  • 需要维持登录态?用 requests.Session(),它自动复用 Cookie 和连接:
s = requests.Session()
s.get("https://httpbin.org/cookies/set/sessioncookie/123456789")
r = s.get("https://httpbin.org/cookies")  # 会带上上面设置的 cookie
print(r.json())  # {'cookies': {'sessioncookie': '123456789'}}

异常处理与超时控制:让代码更健壮

网络不稳定,必须捕获异常,否则程序容易崩:

try:
    response = requests.get("https://httpbin.org/delay/5", timeout=3)
except requests.exceptions.Timeout:
    print("请求超时了")
except requests.exceptions.ConnectionError:
    print("连不上服务器")
except requests.exceptions.RequestException as e:
    print(f"其他请求错误:{e}")
  • timeout 推荐显式设置,单位秒,可传元组 (连接超时, 读取超时)
  • 统一捕获 requests.RequestException 可覆盖大多数异常类型
  • 避免不加防护地调用 .json(),先用 .ok 或状态码判断响应是否有效

requests 库上手快,但细节决定成败——头怎么设、超时怎么控、异常怎么兜底、会话怎么复用,这些才是真正写好网络请求的关键。不复杂但容易忽略。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>