%E7%AC%AC%E4%B8%80%E6%AC%A1
import urllib c='%E7%AC%AC%E4%B8%80%E6%AC%A1' e=urllib.unquote(c) c='1' f=urllib.unquote(c) print e #输出结果: 第一次
print f # 输出结果: 1
上面的代码是在Windows下Pycharm里测试输出的,结果符合预期.前端
在开发代码中写入后,使用postman进行测试的时候,是能够的.但当和前端页面进行联合调试的时候,就出现了问题.post
import urllib def select_seller(request,keyword): logging.debug(keyword) #logging.debug 接收到的参数%E7%AC%AC%E4%B8%80%E6%AC%A1
keyword = urllib.unquote(keyword) logging.debug(keyword) # 解码后:第ä¸<80>次
import urllib def select_seller(request,keyword): logging.debug(type(keyword)) #<type 'unicode'>
keyword = urllib.unquote(keyword)
因此解决办法,是使用str()将接收到的参数转化为str类型测试
import urllib def select_seller(request,keyword): logging.debug(type(keyword)) # <type 'unicode'>
keyword = urllib.unquote(keyword) logging.debug(keyword) # 解码后:第ä¸<80>次
keyword = str(keyword) logging.debug(type(keyword)) # <type 'str'>
keyword = urllib.unquote(keyword) logging.debug(keyword) # 解码后:第一次
这样结果就是符合预期的中文关键字,能够进行下一步的操做了.url
至于上面的乱码问题,由于接收到的参数是Unicode类型,urllib.unquote()处理后,依然是Unicode类型.可是把接收到参数中的”%”替换成了’\x’,变成了ascii码字符串,能够参考'https://www.ascii-code.com/',里面对应的值,就能够知道结果为什么出现.spa