1、需要的环境

Python2.X
Requests 库

 

2、单字段发送单个文件

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


1.  
2.  
data = None
3.  
files = { ... }
4.  
r = requests.post(url, data, files=files)

而这个files参数是可以接受很多种形式的数据,最基本的2种形式为:
字典类型
元组列表类型

 

 

2.1、字典类型的files参数

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

 

 


1.  
{
2.  
"field1" : ("filename1", open("filePath1", "rb")),
3.  
"field2" : ("filename2", open("filePath2", "rb"), "image/jpeg"),
4.  
"field3" : ("filename3", open("filePath3", "rb"), "image/jpeg", {"refer" : "localhost"})
5.  
}

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

 

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

 

缺省的话则会使用默认值


除了上面的使用形式,其实requests还是支持一个更简洁的参数形式,如下

 


1.  
2.  
"field1" : open("filePath1", "rb"),
3.  
"field2" : open("filePath2", "rb"),
4.  
"field3" : open("filePath3", "rb")
5.  
}

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


1.  
{
2.  
"field1" : ("filename1", open("filePath1", "rb")),
3.  
"field2" : ("filename2", open("filePath2", "rb")),
4.  
"field3" : ("filename3", open("filePath3", "rb"))
5.  
}

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

 


1.  
2.  
"field1" : open("filePath1", "rb").read()
3.  
}

这里的filename的值为field1

 

 

2.2、元组列表类型的files参数

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

 

 


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

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


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

3、单字段发送多个文件【即上传文件时,设置为多选了】

3.1、字典参数形式


1.  
2.  
"field1" : [
3.  
"filename1", open("filePath1", "rb")), 
4.  
"filename2", open("filePath2", "rb"), "image/png"), 
5.  
"filePath3", "rb"),
6.  
"filePath4", "rb").read()
7.  
               ]
8.  
}

3.2、元组列表形式


1.  
2.  
"field1" , ("filename1", open("filePath1", "rb"))),
3.  
"field1" , ("filename2", open("filePath2", "rb"), "image/png")), 
4.  
"field1" , open("filePath3", "rb")),
5.  
"field1" , open("filePath4", "rb").read())
6.  
]

上面2种形式发送的请求,所有的文件都会在同一个字段下,后台服务只要从field1字段就可以获取全部的文件对象

 

 

4、同时发送普通数据字段

上面介绍的是使用发送文件内容请求,而有时候我们在发送文件的同时还需要发送普通的数据字段,此时普通数据字段直接存在data参数中即可,如下:

 

 

 

 


1.  
data = {"k1" : "v1"}
2.  
files = {
3.  
"field1" : open("1.png", "rb")
4.  
}
5.  
r = requests.post("http://httpbin.org/post", data, files=files)