python open函数中的newline参数问题

python版本:2.6
用open函数打开csv文件,提示TypeError: 'newline' is an invalid keyword argument for this function。(newline是为了解决写入时新增行与行之间的一个空白行问题。)

  • 原因: python 2.6 open函数中无newline参数。python 3以上版本中会有newline这个参数。
  • 解决办法:open(‘xxx.csv’,'w') 改写为 open(‘xxx.csv’,'wb')
读写模式

r :只读
r+ : 读写
w : 新建(会对原有文件进行覆盖)
a : 追加
b : 二进制文件

常用的模式有:
"a" 以"追加"模式打开, (从 EOF 开始, 必要时创建新文件)
"a+" 以"读写"模式打开
"ab" 以"二进制 追加"模式打开
"ab+" 以"二进制 读写"模式打开

"w" 以"写"的方式打开
"w+" 以"读写"模式打开
"wb" 以"二进制 写"模式打开
"wb+" 以"二进制 读写"模式打开

"r+" 以"读写"模式打开
"rb" 以"二进制 读"模式打开
"rb+" 以"二进制 读写"模式打开

csv文档出现中文乱码
  • 解决办法:用记事本打开csv文件,另存编码为ANSI的csv文件,再用Excel打开csv文件,就会发现中文乱码问题已解决

换个角度,如果要Python读取csv文件时,正确识别到中文,就需要把csv文件编码格式utf-8格式。

Python读取中文字段出现乱码

用Python连接数据库后,打印中文字段,是乱码。
解决办法:

  • 方法1:在脚本开头添加注释 #encoding=utf-8
    #!usr/local/python/bin/python
    #encoding=utf-8
  • 方法2:导入json包,利用json.dumps(dict, encoding='utf-8',ensure_ascii=False
    import json
    json.dumps(变量名,encoding='utf-8',ensure_ascii=False
    例子:
dict={'name':'张三'}
print dict
print json.dumps(dict,encoding='utf-8',ensure_ascii=False)

list=[{'name':'张三'}]
print list
print json.dumps(list,encoding='utf-8',ensure_ascii=False)

row=SQL查询结果
print('{}').format(json.dumps(row,encoding='utf-8',ensure_ascii=False))
print'内容:%s'%(json.dumps(row,encoding='utf-8',ensure_ascii=False))
print(json.dumps(row,encoding='utf-8',ensure_ascii=False))
  • 方法3:开头设置默认编码
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
  • 方法4:当row是元组时,下面3行都可以成功打印出中文
print(row[0].decode('utf-8'))
print row[0]
print('{}').format(row[0])