Python中还原JavaScript的escape函数编码后字符串的方法
2023-06-13 09:15:44 时间
遇到一个问题需要用Python把JavaScript中escape的中文给还原,但找了大半天,也没有找到答案,只好自己深入研究解决方案。
我们先来看在js中escape一段文字的编码
a=escape("这是一串文字");
alert(a);
输出:
%u8FD9%u662F%u4E00%u4E32%u6587%u5B57
咋一看,就感觉有点类似json格式,我们来看看标准的json格式编码同样的汉子“这是一串文字”
#encoding=utf-8
importjson
a="这是一串文字"
printjson.dumps(a)
输出:
经过对比,其实就是jsescape编码每个汉子都是“%u”符号加4位字符编码,而json编码每个汉子都是“\u”符号加4位字符编码,这样的话,我们可以利用字符串替换操作还原json格式,然后再使用json模块loads就好
#encoding=utf-8
importjson
#jsescape字符串编码
c="%u8FD9%u662F%u4E00%u4E32%u6587%u5B57"
#还原Json对象
jsonObj= """+"".join([(iand"\\"+i)foriinc.split("%")])+"""
printjson.loads(jsonObj)
特别记得在把“%”替换为“\”符号以后还要再使用双引号把字符串包一下,才能算是一个json对象,然后才能json.loads出来
后来,好不容易在一个站点上看到了更简便的方法。代码如下:
#encoding=utf-8
c="%u8FD9%u662F%u4E00%u4E32%u6587%u5B57"
print"".join([(len(i)>0andunichr(int(i,16))or"")foriinc.split("%u")])
它的思路其实都差不多,把“%u”号替换掉,剩下每一个都是4位固定长度的字符编码,最后在unichr反编码回中文字符。
相关文章
- 如何为pycharm配置Python解释器_pycharm选择python解释器
- python十进制转换_Python 进制转换
- Python上位机软件图形界面实战(2)[通俗易懂]
- python中矩阵的转置_[转]Python中的矩阵转置[通俗易懂]
- python中delay__python delay函数「建议收藏」
- python 保留两位小数
- python自动化办公操作:mysql存储、时间、遍历文件夹、拼接地址、读取pdf、word、测试代码运算速度2021.8.2
- python 迭代器和生成器(5.2)
- python中int的取值范围_int32的取值范围是多少?
- python画爱心[通俗易懂]
- lambda python表达式_Python的条件表达式和lambda表达式实例
- python判断文件后缀_Python 判断文件后缀是否被篡改
- Python win32api_python api文档
- pycharm如何调试python程序_Pycharm断点调试Python程序的步骤方法
- python递归函数讲解_Python递归函数实例讲解
- Python进阶之递归算法详解
- 纯 Python 实现的图片压缩工具
- python类型注解
- python-Python与PostgreSQL数据库-使用Python执行PostgreSQL查询(一)
- python设置进程的环境变量详解编程语言
- JavaScript学习总结(二十)——Javascript非构造函数的继承详解编程语言
- 小白的Python之路 day5 python模块详解及import本质编程语言
- Python学习:6.python内置函数详解编程语言
- Linux创建Python文件的步骤(linux新建python文件)
- Linux系统如何运行Python脚本(linux执行python脚本)
- 学习Python精通SQL Server操作技巧(python操作sqlserver)
- 使用Python连接SQL Server数据库(python连接sqlserver数据库)
- python抓取京东价格分析京东商品价格走势