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或网页对数组单个元素处理而不是数组整体。