python的中文数组输出乱码问题

1-先来几组测试
测试1:在控制台上

list1 = ['哈哈', 'haha']
print list1
for item in list1:
    print item
print ','.join(list1)

测试结果:
[‘\xb9\xfe\xb9\xfe’, ‘haha’]
哈哈
haha
哈哈, haha
这里同时给出了在控制台的解决方式:一个一个输出就好


测试2:把它展现在网页上

# 这里使用Django框架,views.py文件中,
list1 = ['哈哈', 'haha']
def hello(request):
    list1 = ['哈哈', 'haha']
    return render_to_response('index.html', {'list1': list1})

在网页中展现出的数据是’\xb9\xfe\xb9\xfe’, ‘haha’


那么在网页中怎么解决呢?先看下面这种解决方式:

#views.py文件不变,继续传送list1数组

<p>
list1:
[
{% for item in name %}
    {{ item }}
    {% if not forloop.last %}
        ,
    {% endif %}
{% endfor %}
]
p>

结果:
list1: [‘哈哈’, ‘haha’]
达到了预期效果。


2-总结
数据没有任何问题,无论mysql还是python还是html我的都是utf-8编码的,但是当中文字符串组成数组时,python会自动进行一些处理(我不知道是怎么处理的),结果就是把它存储为[‘\xb9\xfe\xb9\xfe’, ‘haha’]这种效果了,对于数组整体print和网页在处理显示不会进一步处理,但是对于单个元素print和网页都会进一步处理的,所以我们所有做的工作就是让print或网页对数组单个元素处理而不是数组整体。

你可能感兴趣的:(----python)