python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > python使用requests.post方法传递Excel数据

python使用requests.post方法传递form-data类型的Excel数据的示例代码

作者:weixin_43962547

这篇文章介绍了python使用requests.post方法传递form-data类型的Excel数据的示例代码,某些post接口,需要发送multipart/form-data类型的数据,如何使用python requests来模拟这种类型的请求发送呢?补充讲解了python使用requests post请求发送form-data类型数据,一起看看吧

python使用requests.post方法传递form-data类型的Excel数据

import datetime
import json
import random
import string
import requests
from requests_toolbelt import MultipartEncoder
# 在企业微信群里发消息
def log(day):
	url = 'https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=xxx'
	headers = {
		"Content-Type":"application/json"
	}
	data = {
		"msgtype":"text",
		"text":{
			"content":"xxx"
		}
	}
	response = requests.post(url=url,headers=headers,data=json.dumps(data))
	print(response.status_code)
	print(response.text)
# 测试环境
# url = "https://xxx"
# 生产环境
url = "https://xxx"
# 定义字符集
chars = string.ascii_lowercase+string.digits+string.ascii_uppercase
# 生成长度为32的随机字符串
random_str = ''.join(random.sample(chars, 32))
print(random_str)
# 设置日期
day = ((datetime.datetime.now()-datetime.timedelta(days=1)).strftime("%Y-%m-%d"))
# 配置数据
data = MultipartEncoder({
	'requestId':random_str,
	'docType':'invoice',
	# 'application/octet-stream'这个可以通过apifox等软件post一次后看请求内容获取
	'file': ('xxx.csv', open('xxx.csv', 'rb'), 'application/octet-stream'),
	# 'file': ('xxx.csv'), open(xxx.csv', 'rb'), 'application/octet-stream'),
})
# 配置请求头
headers = {
   # 'Authorization': 'Bearer xxx',    # 测试环境
   'Authorization': 'Bearer xxx',  # 生产环境
   'User-Agent': 'Apifox/1.0.0 (https://apifox.com)',
   'Accept': '*/*',
   # 'Host': 'xxx',   # 测试环境
   'Host': 'xxx',     # 生产环境
   'Connection': 'keep-alive',
   'Content-Type': data.content_type
}
print(data.content_type)
# 返回结果
response = requests.post(url, headers=headers, data=data)
print(response.text)
if json.loads(response.text)['code'] == "200":
	print("ok")
	log(day)

补充:

python 使用requests post请求发送form-data类型数据

某些post接口,需要发送multipart/form-data类型的数据,如何使用python requests来模拟这种类型的请求发送呢?

根据http/1.1rfc 2616的协议规定,我们的请求方式有OPTIONS、GET、HEAD、POST、PUT、DELETE、TRACE等。

http协议规定以ASCII码传输,建立在tcp,ip协议之上的引用规范。规范内容把http请求分成3个部分:状态行,请求头,请求体。所有的方法,实现都是围绕如何使用和组织这三部分来完成了,万变不离其宗。

post请求有两种编码格式:application/x-www-form-urlencoded 和multipart/form-data

multipart/form-data

multipart/form-data格式不仅可以传输参数,还可以传输文件。也是在post基础上演变而来的,具体如下:

关于boundary:

并且在结束的时候,不仅前缀要加双短横线,后缀也要加,代表结束。

boundary快问快答:

Q:boundary的值是用户可以自由定义的吗?
A:是的,但为了避免和正常文本重复了,尽量要使用复杂一点的内容。

Q:boundary的作用?
A:分割参数,类似于普通post请求中的 &

使用python发送multipart/from-data类型数据

有两种方式:

在官方网站上,requests模拟一个表单数据的格式如下:

files = {{name}: (<filename>, <file object>,<content type>, <per-part headers>)}

这一行模拟出来的post数据为:

Content-Disposition: form-data; name={name};filename=<filename>
Content-Type: <content type>
<file object>
--boundary

注:如果filename 和 content-Type不写,那么响应模拟post的数据就不会有二者。

通过上述说明,我们可以构造出files后直接post请求发送即可:

files = {
    'schoolId': (None, -1),
    'schoolName': (None, ""),
    "reward": (None, 5),
    "publishText": (None, "测试测试"),
    "tags": (None, 1),
    'image': ('image.jpg', open('%s/resource/upload_images/image.jpg' % PATH_DIR, 'rb'), 'application/octet-stream')
}
response = requests.post(url, files=files)

猪猪侠要努力呀!

到此这篇关于python使用requests.post方法传递form-data类型的Excel数据的文章就介绍到这了,更多相关python使用requests.post方法传递Excel数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文