python 报错FileNotFoundError: [Errno 2] No such file or directory

目录

1.FileNotFoundError: [Errno 2] No such file or directory

2.SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape

3.SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape

 4.TypeError: read_file() got an unexpected keyword argument 'encoding


在学习python过程中 遇到了这个问题,

1.FileNotFoundError: [Errno 2] No such file or directory

翻译一下的意思是,这段代码报错信息表示在运行时尝试打开名为 "news.txt" 的文件,但系统找不到这个文件,因此引发了 FileNotFoundError 异常。

但是这个news.txt文件确实已经被创建,那么报错的原因就是代码编写问题,那么很可能是文件路径设置有问题,

再次检查了一下路径发现我代码中写的是相对路径,然后我改成绝对路径,

本以为会顺利解决结果又出现了新的错误

2.SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape

这个错误提示是因为在代码中使用了错误的字符编码,错误提示中提到了 "unicodeescape" 编码无法解码位在 2-3 位置的字节,这表明在读取 "news.txt" 文件时,遇到了一个未被正确解码的 Unicode 字符。

在 Windows 系统中,默认的文本文件编码方式是 GBK(即 GB2312),而在 Linux 和 Mac 系统中,通常使用 UTF-8 编码方式。因此,在读取文件时,需要指定正确的编码方式,以确保文件内容的正确性和一致性。
在调用 read_file 函数时,传入的参数'encoding='gbk'',表示使用 GBK 编码方式读取文件内容。如果在 Linux 或 Mac 系统中使用该函数,应该将参数更改为'encoding='utf8'',以确保正确读取文件内容。

因此当尝试读取使用其他编码的文件时,可能会出现这个错误。

要解决这个问题,你需要确保文件的编码格式与 Python 解释器的默认编码格式(UTF-8)一致。如果 "news.txt" 文件实际上使用了其他编码,例如 GBK 或 GB2312,可以尝试修改代码中的编码参数

如果你不确定文件使用的编码格式,可以尝试使用一些工具(如 Notepad++、Sublime Text 等)打开文件并检查其编码格式。在 Notepad++ 中,你可以通过菜单栏的 "编码" -> "转换编码" 来检查和更改文件的编码格式。

这个问题解决之后又出现了新的问题

3.SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape

 这个错误提示仍然是因为代码中使用了错误的字符编码。尽管你已经尝试了修改编码参数,但似乎没有解决这个问题。

错误提示中提到了 "unicodeescape" 编码无法解码位在 2-3 位置的字节,这表明在读取 "news.txt" 文件时,遇到了一个未被正确解码的 Unicode 字符。但此次错误是因为在代码中使用了双斜杠(//)而不是单斜杠(/)作为字符串分割符。
解决这个问题,需要将代码中的分割符更改为单斜杠(/)

修改之后如下图

结果又出现了第四个问题

 4.TypeError: read_file() got an unexpected keyword argument 'encoding

这个错误提示表明在调用 read_file() 函数时,传入了一个意外的关键字参数 'encoding'。这可能是因为尝试了使用 'encoding' 参数来指定文件的编码方式,但实际上这个参数并不属于 read_file() 函数。

问题是在于定义的 read_file() 函数没有接收 encoding 参数。当在调用 read_file() 函数时,传入了一个意外的关键字参数 'encoding',从而导致了报错。
要解决这个问题,你需要修改 read_file() 函数的定义,让它可以接收 encoding 参数。修改后的代码如下:

最终代码

# 1.通过def定义一个函数 函数名  函数参数
def read_file(file_path,encoding):
    """
    读取文件内容
    通过with 创建上下文件资源管理器
    通过open 打开文件
    windows 默认使用gbk

    """

    with open(file_path,'r', encoding='utf8')as f:
       res = f.read()
    return res
# 使用read_file函数读取内容
content = read_file('C:/Users/jin/Desktop/git_work/15.function/news.txt',encoding='gbk' )
print(content)

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值