【python】No such file or directory,为什么我的python打不开文件了?

这篇博客讲述了作者在编写Python脚本时遇到的文件路径问题,具体表现为尝试打开Excel文件时出现FileNotFoundError。作者发现问题是由于Python的工作目录与实际文件所在目录不同导致的。解决方案包括使用os库来查看和修改工作目录,以及通过inspect库获取当前文件路径来正确指定文件位置。此外,还介绍了一种更便捷的方法,即通过获取当前文件的上级目录来创建和操作文件。
摘要由CSDN通过智能技术生成

        最近突发奇想想做一个问卷星数据爬取的脚本,当我在使用pandas打开同级目录下的 1.xlsx的时候,我又看到了极其不想看到的那句话:Traceback (most recent call last),就知道又有问题产生了(寄),问题是这样的:

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

        真是奇了个怪了,我一开始以为是文件的问题,或者是打开方式不对,于是我尝试了各种版本的文件,还是没有打开。在茫茫网海寻找半天之后,我发现是python工作目录的问题,即当前文件所在目录和python的工作目录是不一样的,下边是我的目录:

而从vscode中可以看出我当前的工作路径如下:

python中也提供了查看和修改当前工作目录的函数,在os库里:

print('当前工作目录为:',os.getcwd()) #获取当前工作目录
os.chdir('D:\\program\\python_program\\crawler') #修改当前工作目录
print('修改后的工作目录为:',os.getcwd()) #再次获取当前工作目录

 修改后的结果如下:

        因为修改目录还需要提前知道文件在哪个目录下面,所以我又通过查资料找到了另一种更为简便的方法,通过inspect库获取当前文件所在位置,进一步获取获取当前文件上级目录名,这样我们在对当前文件同级目录下的其他文件进行操作的时候会方便许多,代码如下:

    #在当前文件目录下创建材料收集目录
    current_file_name = inspect.getfile(inspect.currentframe())
    #print(current_file_name) #取当前文件名
    current_file_path = current_file_name[::-1].split('\\',1)[1][::-1]
    #print(current_file_path) #处理当前文件上级目录名
    aim_file_path = '.\collection'
    aim_file_path = current_file_path + aim_file_path
    if not os.path.exists(aim_file_path):
        os.mkdir(aim_file_path) #创建材料收集目录

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值