requests Use body.encode('utf-8') if you want to send it encoded in UTF-8
2024-09-01 14:57:26
基本环境
使用 requests 模块发送 post 请求,请求体包含中文报错
系统环境:centos7.3
python版本:python3.6.8
请求代码:
// 得到中文
param_json = param and json.dumps(param, ensure_ascii=False) with requests.Session() as session:
resp = session.post(url, data=param_json, timeout=HTTP_POST_TIMEOUT, headers=headers, **kwargs)
汉字报错,报错详细内容: 'latin-1' codec can't encode characters in position 545-547: Body ('未识别') is not valid Latin-1. Use body.encode('utf-8') if you want to send it encoded in UTF-8
解决方法
数据在网络中都是通过字节数据进行传输的, 在发送数据时, requests 模块需要将字符串编码成 bytes 进行传输.
而请求体 body 里面有汉字,requests里边的 URL 编码方式默认是 拉丁 编码,无法对中文内容进行编码
解决方式就是手动使用 utf-8 字符集对 data 进行编码.
// 得到中文
param_json = param and json.dumps(param, ensure_ascii=False) with requests.Session() as session:
resp = session.post(url, data=param_json.encode("utf-8"), timeout=HTTP_POST_TIMEOUT, headers=headers, **kwargs)
参考脚本之家:https://www.jb51.net/article/140386.htm
最新文章
- jcFeather Maya 羽毛插件
- SQL取出 所有周六 周日的日期
- Technical reading July-15
- 【转载】ASP.NET MVC Web API 学习笔记---联系人增删改查
- 初探百度F.I.S — 由工具到解决方案
- JDBC连接mysql数据库,添加数据
- xampp默认mysql密码设置,修改mysql的默认空密码
- ABAP基本数据类型、通用类型
- Javascript Arguments,calle,caller,call,apply
- (转载)OC学习篇之---第一个程序HelloWorld
- 哟西,CLOUDSTACK第一步,搞定
- Qt编程之QtScript
- dotnet tools 运行 dotnet run
- [转]Linux挂载点介绍及桌面服务器分区方案
- WinForm中,设置不显示窗口的标题栏
- python 打包下载 zipfile &; tarfile
- ubuntu 14.04中安装 ruby on rails 环境
- pandas修改全列的时间格式 无需使用apply
- Effective C++ 随笔(4)
- Android Studio快捷键——编辑篇
热门文章
- Docs-.NET-C#-指南-语言参考-预处理器指令:#endif(C# 参考)
- SQL SERVER SELECT语句中加锁选项的详细说明
- 阶段5 3.微服务项目【学成在线】_day18 用户授权_08-动态查询用户的权限-用户中心查询用户权限
- QML登录界面
- Qt编写自定义控件48-面板窗体控件
- c# 调用mysql数据库验证用户名和密码
- 【C# 开发技巧】番外篇故事-我是一个线程
- 共享文件word / excel /ppt 被用戶自己锁定无法编辑-解決方法
- 《Hadoop大数据技术开发实战》学习笔记(一)
- 移动架构-MVVM框架