技术背景

在使用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

更多原著文章请参考:https://www.cnblogs.com/dechinphy/

python3查看文件是否存在,以及读、写与执行的属性的更多相关文章

  1. C++文件处理(一):读/写txt文件

    C++文件处理与C语言不同,C++文件处理使用的是:流(stream) C++头文件fstream定义了三个类型来支持文件IO

  2. Pandas 基础(4) - 读/写 Excel 和 CSV 文件

    这一节将分别介绍读/写 Excel 和 CSV 文件的各种方式: - 读入 CSV 文件 首先是准备一个 csv 文件, 这里我用的是 stock_data.csv, 文件我已上传, 大家可以直接下载 ...

  3. day9 python学习 文件的操作 读 写 seek

    文件的操作 1   文件的打开操作: 文件句柄 = open('文件路径', '模式') f=open('wangyakun','a+',encoding='utf-8') #文件名, 如果是绝对路径 ...

  4. Linux 查看文件被那个进程写数据

    目录 背景 步骤 获取写文件的进程号 文件被那个进程使用,写数据不是用lsof可以找出来吗,但现实情况是lsof没找出来T_T 背景 centos7 在某一段时间监控报警磁盘使用率达99%,由于监控属 ...

  5. openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库

    openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库¶ https://www.osgeo.cn/openpyxl/index.html

  6. java读/写文件

    读取文件参考:https://blog.csdn.net/weixin_42129373/article/details/82154471 写入文件参考:https://blog.csdn.net/B ...

  7. linux chmod 给目录或文件赋权限 可读可写可执行

    前提:  mode权限设定字串,格式:[ugoa...][[+-=][rwxX]...][,...] 其中u表示拥有者(user),g表示与拥有者属于同一个群体(group),o表示其他以外的人(ot ...

  8. Linux命令: 向文件写内容,编辑文件,保存文件,查看文件,不保存文件

    1.找到要编辑的文件 2.敲  vi t1.txt ,显示文件内容(vim命令) 3.敲 i,最下面变成INSERT 4.编辑自己想要的内容 5a.敲ESC:wq回车 5b.如果不想保存文件在时敲ES ...

  9. python3.7 文件操作

    #!/usr/bin/env python __author__ = "lrtao2010" #python3.7 文件操作 # r 只读,默认打开方式,当文件不存在时会报错 # ...

  10. Linux下查看文件和文件夹大小

     当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择. df可以查看一级文件夹大小.使用比例.档案系统及其挂入点,但对文件却无能为力.    du可以查看文件及文件夹的大小. ...

随机推荐

  1. 【笔记整理】请求携带cookie的两种方法

    """ 方法一:在请求头header中携带Cookie请求头信息(因为本身Cookie就是用请求头传递的....) 方法二:使用cookie参数传递cookie字典 &q ...

  2. 【笔记】Ribbon负载均衡伪随机算法

    伪随机:思路 当一个下标(伪服务)连接被调用两次,第三次如果还是它,就让再随机一次 当重复随机到一台服务两次时判断第三次是否还是它 是的话 我们要进行 再次随机 也就是第三次 package top. ...

  3. 当创建pvc后,kubernetes组件如何协作

    本文分享自华为云社区<当创建一个pvc后,kubernetes会发生什么?>,作者:可以交个朋友. 一.背景 外部存储接入 Kubernetes 的方式主要有两种:In-Tree 和 Ou ...

  4. puppeteer的简单使用

    引言 对于编写应用程序,尤其是要部署上线投入生产使用的应用,QA是其中重要的一环,在过去的工作经历中,我参与的项目开发,大多是由测试同学主要来把控质量的,我很少编写前端方面的测试代码,对于测试工具的使 ...

  5. 2023-11-15:用go语言,如果一个正方形矩阵上下对称并且左右对称,对称的意思是互为镜像, 那么称这个正方形矩阵叫做神奇矩阵, 比如 : 1 5 5 1 6 3 3 6 6 3 3 6 1 5

    2023-11-15:用go语言,如果一个正方形矩阵上下对称并且左右对称,对称的意思是互为镜像, 那么称这个正方形矩阵叫做神奇矩阵, 比如 : 1 5 5 1 6 3 3 6 6 3 3 6 1 5 ...

  6. spring-mvc 系列:HttpMessageConverter(@RequestBody、RequestEntity、@ResponseBody、@RestController、ResponseEntity、文件上传下载)

    目录 一.@RequestBody 二.RequestEntity 三.@ResponseBody 四.SpringMVC处理json 五.@RestController 六.ResponseEnti ...

  7. 案例解析丨 Spark Hive 自定义函数应用

    摘要:Spark目前支持UDF,UDTF,UDAF三种类型的自定义函数. 1. 简介 Spark目前支持UDF,UDTF,UDAF三种类型的自定义函数.UDF使用场景:输入一行,返回一个结果,一对一, ...

  8. CSV:简单格式下隐藏的那些坑

    摘要:本文将盘点处理CSV数据时我遇到的一些坑. 本文分享自华为云社区<CSV-简单格式下隐藏的那些坑>,作者:aKi. 前言 CSV(Comma-Separated Values),是一 ...

  9. 游戏“外挂”?—— AI生成游戏最强攻略

    作为一名快乐的肥宅,玩游戏是居家必备,无论是王者荣耀.吃鸡.原神这些大热游戏,还是跳一跳.合成大西瓜.2048.这些风靡一时得小游戏,咱都有涉及.但是为了成为一个"头号玩家",我总 ...

  10. 一文讲清楚FusionInsight MRS CDL如何使用

    摘要:CDL是一种简单.高效的数据实时集成服务,能够从各种OLTP数据库中抓取Data Change事件,然后推送至Kafka中,最后由Sink Connector消费Topic中的数据并导入到大数据 ...