python 元组编码和解码问题

先看一个例子:

(u'agentEnum', True, '200', {u'msg': u'u6210u529f', u'code': 1})

在2.7.15版本中,如果有下面代码:

def foo(*args):
    with open("path", "w") as f:
        line = args
        f.write(line)
        f.close()
    
if __name__ == "__main__":
    data = (u'agentEnum', True, '200', {u'msg': u'u6210u529f', u'code': 1})
    foo(data)

  写入文件时候,很容易出现乱码的问题

如果直接对返回的字符串调用encode或者先str(data)然后encode,都会报错;

有一个不是很理想的解决方法是:

line = ""
for i in range(0, len(list(args))): 
    line =  "%s %s" % (line, args)
with open(path, "w") as f:
    f.write(line)

注意:   

   *args返回的值是元组形式的,如果为一个值的时候:(xxx,)

   *所以,经常会遇到做这个处理的地方

另外:

  正常的,如果传给你的是一个字符串,而不是一些混合类型的数值,遇到乱码问题,大可以使用encode,decode方法处理;

加餐:

  如果在调试的时候可以在IDE中设置断点,看每步生成的数据种类,然后决定怎么转码

  也可以使用一下方式,打印关注数据的格式:

  

import chardet

data = "xxx"

print chardet.detect(data)

  

chardet.detect() 即使是报错,也会返回格式信息

python 2.x在使用汉字的时候,如果定义的都是Unicode类型,编码问题会少很多

比如:

  a = u“测试”

还有一种情况比较特殊:

某些软件在保存一个以UTF-8编码的文件时,默认会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。在有些软件可以控制是否插入BOM。如果在有BOM的情况下,在读取时需要自己去掉这些字符,python中的codecs module定义了这个常量

原文地址:https://www.cnblogs.com/chenadong/p/9997362.html