python requests 发送 上传 多个文件

目录

1.上传文件 代码实例

2.files参数 字典类型

3.files参数 元组列表类型


1.上传文件 代码实例

在requests中发送文件的接口只有一种,那就是使用requests.post的files参数, 请求形式如下:

import requests
 
url = 'http://127.0.0.1/upload'
files = {'file': open('D:/test.apk', 'rb')}           
data = {'xxx':xxx,'xxx':xxx}
  
response = requests.post(url, files=files, data=data)
json = response.json()
print(json)

data参数:是需要发送普通的数据字段

files参数:是需要上传的文件信息,可以接受很多种形式的数据,最基本的2种形式为:

  • 字典类型
  • 元组列表类型

2.files参数 字典类型

官方推荐使用的字典参数格式如下:

{
  "field1" : ("filename1", open("filePath1", "rb")),
  "field2" : ("filename2", open("filePath2", "rb"), "image/jpeg"),
  "field3" : ("filename3", open("filePath3", "rb"), "image/jpeg", {"refer" : "localhost"})
} 

这个字典的key就是发送post请求时的字段名, 而字典的value则描述了准备发送的文件的信息;从上面可以看出value可以是2元组,3元组或4元组。这个元组的每一个字段代表的意思一次为

("filename", "fileobject", "content-type", "headers")

缺省的话则会使用默认值。除了上面的使用形式,其实requests还是支持一个更简洁的参数形式,如下

{
  "field1" : open("filePath1", "rb"),
  "field2" : open("filePath2", "rb"),
  "field3" : open("filePath3", "rb")
}

这种形式的参数其等同效果如下, 其中filename是filepath的文件名

{
  "field1" : ("filename1", open("filePath1", "rb")),
  "field2" : ("filename2", open("filePath2", "rb")),
  "field3" : ("filename3", open("filePath3", "rb"))
}

当然,你还可以这样发送一个文件请求

{
  "field1" : open("filePath1", "rb").read()
}

这里的filename的值为field1

3.files参数 元组列表类型

其实元组列表的形式与字典的形式基本一样,除了最外层的包装不一样;而在requests内部最终会把字典参数形式 转换 为 元组列的形式。官网推荐的用法如下:

[
  ("field1" : ("filename1", open("filePath1", "rb"))),
  ["field2" : ("filename2", open("filePath2", "rb"), "image/jpeg")],
  ("field3" : ("filename3", open("filePath3", "rb"), "image/jpeg", {"refer" : "localhost"}))
]

列表里面的子项可以是元组,也可以是列表;同样这里也支持简介的形式,如下:

[
  ("field1" : open("filePath1", "rb"))),  ##filename 使用的是filepath的文件名
  ("field2" : open("filePath2", "rb").read())) ##filename 使用的是键值,即 field2
]

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值