Python requests用法和django后台处理详解
1、requests 的常见用法
requests 除了 url 之外,还有 params, data 和 files 三个参数,用于和服务器后台交互。
1.1、提交查询
注意 get 只支持 params ,不支持 data 和 files。
1.2、提交表格
注意,requests.post既支持data,也支持params:
1 2 3 4 5 6 | requests.post(form_submit_url, data = { "user" : user, "password" : password, }, params = { "pool" : pool, }) |
1.3、在提交时附加文件:
1 2 3 4 5 6 7 | files = [ "a.csv" , "b.xml" ] # 注意file需要以binary形式打开。 files = [( "files" , (os.path.basename( file ), open ( file , "rb" ))) for file in files] r = requests.post(url, files = files, data = data, params = params) |
1.4、保持状态
使用 session 保持状态,先登录,再提交表格:
1 2 3 | session = requests.Session() session.get(login_url, params) session.post(form_submit_url, data) |
1.5、查看结果
最重要的是status_code、reason和content三个成员变量:
1 2 3 4 5 6 | r = requests.post(url, files = files, data = data, params = params) if r.status_code ! = 200 : print (r.status_code, r.reason) # 打印出错信息。 else : print (r.content) # 服务器返回结果 |
2、django 的处理
2.1、params 传入的参数
对于 requests 通过 params 传入的参数,可以通过request.GET获取:
1 2 3 4 | def handler(request): return request.GET[ "pool" ] # 若未传入参数,将抛出异常 # return request.GET.get("pool") # 当没有传入该参数时,返回None # return request.GET.get("pool", "abc") # 默认为abc |
2.2、data 传入的参数
对于 requests 通过 data 传入的参数,可以通过request.POST获取:
1 2 3 4 | def handler(request): return request.POST[ "user" ] # 若未传入参数,将抛出异常 # return request.POST.get("user") # 当没有传入该参数时,返回None # return request.POST.get("user", "abc") # 默认为abc |
2.3、files 传入的参数
对于 requests 通过 files 传入的参数,可以通过request.FILES获取:
1 2 3 4 5 | def handler(request): for file in request.FILES.getlist( "files" ): name = file .name content = file . file .read() # is binary open (name, "wb" ).write(content) # 保存到本地 |
总结
到此这篇关于Python requests用法和django后台处理的文章就介绍到这了,更多相关requests用法和django后台处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

微信公众号搜索 “ 脚本之家 ” ,选择关注
程序猿的那些事、送书等活动等着你
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 reterry123@163.com 进行投诉反馈,一经查实,立即处理!
相关文章
教你用python提取txt文件中的特定信息并写入Excel
这篇文章主要给大家介绍了如何利用python提取txt文件中的特定信息并写入Excel的相关资料,Python是一个强大的语言,解决这点问题非常简单,文中通过示例代码介绍的非常详细,需要的朋友可以参考下2021-11-11
最新评论