python文件读写

本文详细比较了Python2和Python3在读取文件时的差异,重点讲解了open函数参数扩展、Python2支持不同编码的方法,以及如何处理字符编码错误,如UnicodeDecodeError,通过示例代码展示了UTF-8和gb18030编码的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

读文件

python2&python3差异

普通模式(python2、python3通用)

f = open(fileName, mode='r')

open函数在python2和python3差异点:

python3支持多个参数,python2只有2个参数,且对于文件编码不支持

#python3
def open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True): # known special case of open

#python2
open(name[, mode[, buffering]])

python2如何支持不同编码的文件读写?

import codecs
# 这里增加u是为了防止乱码,详见 https://blog.csdn.net/songlh1234/article/details/83791205
fileNameWrite = u'测试codecs写入gbk.txt'
fileWrite = codecs.open(fileNameWrite, 'w', "gbk")
fileWrite.write('设备编号,deviceID,ehomeKey,执行结果,返回报文\n')

另外这里需要注意,以上代码在python3下执行正常,但write这一行代码在python2下会报错:

UnicodeDecodeError: 'ascii' codec can't decode byte 0xe8 in position 0: ordinal not in range(128)

需要额外设置默认字符

try:
    # Python2
    reload(sys)
    sys.setdefaultencoding("utf-8")
except NameError:
    print('NameError')

示例代码

UTF-8编码方式打开文件

def openFile(path):
    f = None
    try:
        f = open(path, encoding='UTF-8')
    except FileNotFoundError:
        print("open file %s error" % path)
    else:
        print("open file %s ok" % path)
    return f

gb18030编码方式打开文件

def openFile(path):
    f = None
    try:
        f = open(path, encoding='gb18030')
    except FileNotFoundError:
        print("open file %s error" % path)
    else:
        print("open file %s ok" % path)
    return f

说明:如果不带encoding参数,会采用系统编码,Windows下默认为gbk
读取文件内容

file_name = r"D:\1.txt"
f = openFile(file_name)
for line in f:
    print(line)

文件路径

获取当前路径:

os.getcwd()

拼接路径和文件名

fileName1 = os.path.join(filePath, fileName) 

获取文件所在的文件目录

directory_path = os.path.dirname(file_name) # 根据绝对路径,返回所在的目录

问题处理:字符编码报错

读取文件字符时遇到如下问题:

UnicodeDecodeError: ‘gbk’ codec can’t decode byte 0xa6 in position 1909: illegal multibyte sequence

问题原因:文档默认使用’gbk’编码打开,但文档实际编码是gb18030,有些字符无法被gbk识别。

解决方案:打开文件的时候可以指定字符集为gb18030

f = open(path, encoding="gb18030")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值