zoukankan      html  css  js  c++  java
  • python3查看文件是否存在,以及读、写与执行的属性(转)

     

    技术背景

    在使用python对系统文件进行操作的项目中,经常需要用到对本地文件的存在和读写进行判断的操作。最常用的比如os.exists函数,可以很方便的判断给定的文件名是否存在于系统中。但是这里我们介绍的是一个更加专业的判断方案:os.access。使用这个方法,不仅可以判断文件是否存在,还可以判断当前用户对这个文件的读、写和执行的属性。

    代码实现

    这里我们构造一个名为osaccess_test.py的测试项目,这个项目采取了读取命令行的方式来获取需要校验的文件名。对于文件名的校验有4个参数配置:F_OK校验文件是否存在,R,W,X分别校验文件是否具备读、写和执行的权限。如果符合相关的条件选项,则返回值为True。关于返回值的判断,可以用is True或者==1或者直接if condition都是可以的。关于测试的结果,可以参考下一个章节。

    # osaccess_test.py
    
    import os
    import sys
    
    if sys.argv[1] == '-n':
        file_name = sys.argv[2] # 从命令行获取文件名参数
    
    if os.access(file_name, os.F_OK) is True:
        print ('File {} exists!'.format(file_name))
    else:
        print ('File {} not exists!'.format(file_name))
    
    if os.access(file_name, os.R_OK):
        print ('File {} can be read!'.format(file_name))
    else:
        print ('File {} can not be read!'.format(file_name))
    
    if os.access(file_name, os.W_OK):
        print ('File {} can be write!'.format(file_name))
    else:
        print ('File {} can not be write!'.format(file_name))
    
    if os.access(file_name, os.X_OK):
        print ('File {} can be executed!'.format(file_name))
    else:
        print ('File {} can not be executed!'.format(file_name))
    

    测试分析

    首先我们测试一个不存在的文件,可以看到当前目录下仅有一个py测试文件:

    [dechin@dechin-manjaro access]$ ll
    总用量 4
    -rw-r--r-- 1 dechin dechin 706  3月 22 10:47 osaccess_test.py
    

    从命令行输入一个文件名为1.txt的参数,并以如下的方式来执行:

    [dechin@dechin-manjaro access]$ python3 osaccess_test.py -n 1.txt
    File 1.txt not exists!
    File 1.txt can not be read!
    File 1.txt can not be write!
    File 1.txt can not be executed!
    

    我们发现所有的判断结果都是False,这也是正确的。接下来测试一个644权限的文件,首先用touch在当前帐号下产生一个1.txt的文件:

    [dechin@dechin-manjaro access]$ touch 1.txt
    [dechin@dechin-manjaro access]$ ll
    总用量 4
    -rw-r--r-- 1 dechin dechin   0  3月 22 10:47 1.txt
    -rw-r--r-- 1 dechin dechin 706  3月 22 10:47 osaccess_test.py
    

    然后执行同样的命令:

    [dechin@dechin-manjaro access]$ python3 osaccess_test.py -n 1.txt
    File 1.txt exists!
    File 1.txt can be read!
    File 1.txt can be write!
    File 1.txt can not be executed!
    

    这次结果就不一样了,除了可执行权限外,其他条件都是满足要求的。为了测试可执行权限,我们将该文件的权限配置改为700测试一下:

    [dechin@dechin-manjaro access]$ chmod 700 1.txt
    [dechin@dechin-manjaro access]$ ll
    总用量 4
    -rwx------ 1 dechin dechin   0  3月 22 10:47 1.txt
    -rw-r--r-- 1 dechin dechin 706  3月 22 10:47 osaccess_test.py
    

    再执行同样的指令:

    [dechin@dechin-manjaro access]$ python3 osaccess_test.py -n 1.txt
    File 1.txt exists!
    File 1.txt can be read!
    File 1.txt can be write!
    File 1.txt can be executed!
    

    到这里我们就发现,所有的检查条件都满足要求了。最后我们还需要测试一个场景,如果是在其他账户下,比如root账户下,创建了一个文件,那么得到的结论是存在文件还是不存在文件呢?首先用su root跳转到root账户下,然后再用touch生成一个空文件:

    [dechin-root access]# touch 2.txt
    [dechin-root access]# ll
    总用量 4
    -rwx------ 1 dechin dechin   0  3月 22 10:47 1.txt
    -rw-r--r-- 1 root   root     0  3月 22 10:59 2.txt
    -rw-r--r-- 1 dechin dechin 706  3月 22 10:47 osaccess_test.py
    

    接着回到创建py文件的帐号下,用同样的指令,但是换一个文件名输入进行测试:

    [dechin@dechin-manjaro access]$ python3 osaccess_test.py -n 2.txt
    File 2.txt exists!
    File 2.txt can be read!
    File 2.txt can not be write!
    File 2.txt can not be executed!
    

    这里我们发现2.txt这个文件还是存在的并且可读的,这跟other组可读是直接相关的,让我们把other组可读的权限去掉再进行测试:

    [dechin-root access]# chmod 640 2.txt 
    [dechin-root access]# ll
    总用量 4
    -rwx------ 1 dechin dechin   0  3月 22 10:47 1.txt
    -rw-r----- 1 root   root     0  3月 22 10:59 2.txt
    -rw-r--r-- 1 dechin dechin 706  3月 22 10:47 osaccess_test.py
    

    还是执行同样的指令:

    [dechin@dechin-manjaro access]$ python3 osaccess_test.py -n 2.txt
    File 2.txt exists!
    File 2.txt can not be read!
    File 2.txt can not be write!
    File 2.txt can not be executed!
    

    结果我们发现,虽然所有的权限都不具备,但是还是可以看到这个文件存在的。

    总结概要

    本文介绍了如何使用os.access的方法来判断系统文件的存在性与读、写和可执行权限等。这在日常文件操作中有着比较重要的意义,意味着我们可以先判断文件是否存在再决定是否删除系统文件,而不是直接用os.remove进行删除操作,如果有异常再进行捕获,这种的操作非常的不符合操作逻辑,而且不优雅。

    版权声明

    本文首发链接为:https://www.cnblogs.com/dechinphy/p/osaccess.html
    作者ID:DechinPhy

  • 相关阅读:
    半夜删你代码队 Day6冲刺
    半夜删你代码队 Day5冲刺
    半夜删你代码队 Day4冲刺
    半夜删你代码队 Day3冲刺
    Scrum 冲刺博客集合
    团队项目6——复审与事后分析
    Alpha阶段项目复审
    事后Postmortem会议
    团队作业5-测试与发布
    Scrum 冲刺第七天
  • 原文地址:https://www.cnblogs.com/xiaoyuxixi/p/15483798.html
Copyright © 2011-2022 走看看