因为js的escape函数处理非字母数字的字符,简单来说,汉字均以%u开始4个十六进制数表示,其他符号转换与python无过大区别,不做辨识
编码
python3使用urillib进行编码,输出结果与js的escape函数的区别在于,%u变为%5Cu,因此只需要在输出时,再进行一次替换即可
py2下为urllib.quote(),其他基本不变
#编码
import urllib
print(urllib.parse.quote('你好哈<as>'.encode('unicode-escape')).replace('%5Cu', '%u'))
%u4f60%u597d%u54c8%3Cas%3E
解码
python 解码escape则不是将%u替换为%5Cu来处理,而是%u替换为\u,进行处理,相当于json字段处理过程
#escape 解码
import urllib
st ="%u4F60%u597D%3Cas%3E".replace('%u', '\\u')
print(st)
k =urllib.parse.unquote(st.encode().decode('unicode-escape'))
print(k)
\u4F60\u597D%3Cas%3E
你好<as>
应用场景
12306的cookie设置时,采用的是escape编码