requests 中data=xxx、json=xxx、params=xxx 分别什么时候用

如果是要做爬虫模拟一个页面提交,看原页面是post还是get,以及Content-Type是什么。

  • GET 请求 使用 params=xxx,查询参数会被编码到 URL 中。
  • POST 请求 ,Content-Type为 application/x-www-form-urlencoded的,使用 data=xxx,(常见于直接 HTML 表单提交)。
  • POST 请求, Content-Type为 application/json的 使用 json=xxx,常见于通过ajax提交。
  • POST 请求, Content-Type为 multipart/form-data的,有上传文件,使用files=files, data=xxx (常见于直接 HTML 表单提交)

  • 如果post请求同时传递 data 和 json 参数时,requests 库会自动忽略 data,并且只发送 json 中的数据作为请求体
  • post请求可以带params=xxx 这个参数。response = requests.post(url, json=json_data, params=xxx) 不会报错。
  • GET 请求不能带 json=json_data 参数。若使你尝试传递 json=json_data 参数,requests 库会忽略它

如果multipart/form-data中一次请求上传多个文件,则

python 复制代码
    files = {
        'file1': ('file1.jpg', file1, 'image/jpeg'),
        'file2': ('file2.jpg', file2, 'image/jpeg')
    }

GET 请求:

python 复制代码
import requests

url = 'https://example.com/api'
params = {
    'name': 'John',
    'age': 30
}

response = requests.get(url, params=params)

相当于get访问 URL:https://example.com/api?name=John\&age=30

POST请求:application/x-www-form-urlencoded

python 复制代码
import requests

url = 'https://example.com/api'
data = {
    'name': 'John',
    'age': 30
}

response = requests.post(url, data=data)

相当于直接网页提交表单

POST请求 application/json (常见于AJAX提交)

python 复制代码
import requests

url = 'https://example.com/api'
data = {
    'name': 'John',
    'age': 30
}

response = requests.post(url, json=data)

POST请求 multipart/form-data

python 复制代码
import requests

url = 'https://acc.abc.com/api/home/UploadIDCard'

# 文件部分
file_path = 'path/to/your/file.jpg'
with open(file_path, 'rb') as file:
    files = {
        'Files': ('idcard_front.jpg', file, 'image/jpeg')  # (filename, file-object, mime-type)
    }

    # 其他参数部分
    data = {
        'name': 'John',
        'age': 30
    }

    # 发起POST请求
    response = requests.post(url, files=files, data=data)
python 复制代码
import requests

url = 'https://example.com/upload'

# 打开多个文件
file1_path = 'path/to/your/file1.jpg'
file2_path = 'path/to/your/file2.jpg'

with open(file1_path, 'rb') as file1, open(file2_path, 'rb') as file2:
    files = {
        'file1': ('idcard_front.jpg', file1, 'image/jpeg'),
        'file2': ('idcard_back.jpg', file2, 'image/jpeg')
    }

    # 其他参数部分
    data = {
        'name': 'John',
        'age': 30
    }
    # 发起POST请求,上传多个文件
    response = requests.post(url, files=files, data=data)
相关推荐
智慧地球(AI·Earth)1 天前
用 Python 构建一个“记性好”的 AI 助手:JSON本地存储和向量检索
人工智能·python·json
五阿哥永琪2 天前
MySQL 中 VARCHAR、TEXT 与 JSON 类型:区别、场景与选型指南
数据库·mysql·json
liliangcsdn3 天前
从长字符串中解析合法json结构的示例
json
ZC跨境爬虫3 天前
3D地球卫星轨道可视化平台开发Day2(轨道错位Bug修复+模块化结构优化)
前端·3d·html·json·bug
ZC跨境爬虫3 天前
3D 地球卫星轨道可视化平台开发 Day1(3D 场景、卫星渲染与筛选交互实现)
前端·3d·html·json·交互
20YC编程社区4 天前
一分钟了解JSON格式,使用场景,和它的优缺点
json
二月十六4 天前
SQL Server 2022 新特性:JSON_OBJECT、JSON_ARRAY、JSON_PATH_EXISTS 详解
json·sqlserver 、
HIT_Weston4 天前
47、【Agent】【OpenCode】本地代理增强版分析(JSON解析)
人工智能·json·agent·opencode
SuperEugene5 天前
Vue3 配置驱动弹窗:JSON配置弹窗内容/按钮,避免重复开发弹窗|配置驱动开发实战篇
前端·javascript·vue.js·前端框架·json
五仁火烧5 天前
前端最常用的两种请求数据格式application/json 和 multipart/form-data 完全解析
前端·javascript·vue.js·json