python-文件操作
来源:互联网 发布:阿里云url中文乱码 编辑:程序博客网 时间:2024/06/09 22:58
python中对文件、文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块。
- 得到当前工作目录,即当前Python脚本工作的目录路径:
os.getcwd()
- 返回指定目录下的所有文件和目录名:
os.listdir()
- 删除一个文件:
os.remove()
- 递归删除目录:
os.removedirs(r"/tmp/a/b/c")
- 判断给出的路径是否是一个文件:
os.path.isfile()
- 判断给出的路径是否是一个目录:
os.path.isdir()
- 判断是否是绝对路径:
os.path.isabs()
- 检验给出的路径是否真地存:
os.path.exists()
- 返回一个路径的目录名和文件名:
os.path.split()
- eg.
os.path.split('/tmp/test/a.md')
返回一个tuple('/tmp/test', 'a.md')
- eg.
- 分离扩展名:
os.path.splitext()
- eg.
os.path.splitext('/tmp/test/a.md')
返回一个tuple('/tmp/test/a', '.md')
- eg.
- 获取路径名:
os.path.dirname()
- 获取文件名:
os.path.basename()
- 运行shell命令:
os.system()
- 读取和设置环境变量:
os.getenv()
与os.putenv()
- 给出当前平台使用的行终止符:
os.linesep
- Windows使用’\r\n’
- Linux使用’\n’而Mac使用’\r’
- 指示你正在使用的平台:
os.name
- Windows为’nt’
- 而对于Linux/Unix用户,它是’posix’
- 重命名:
os.rename(old, new)
- 也可以用于移动文件,类似于系统命令
mv
- 也可以用于移动文件,类似于系统命令
- 创建多级目录:
os.makedirs(r"/tmp/t/a/f/g")
- 创建单个目录:
os.mkdir('/tmp/test')
- 获取文件属性:
os.stat(path)
- 更改文件或目录的权限:
os.chmod(path, mode)
- flags – 可用以下选项按位或操作生成, 目录的读权限表示可以获取目录里文件名列表, ,执行权限表示可以把工作目录切换到此目录 ,删除添加目录里的文件必须同时有写和执行权限 ,文件权限以用户id->组id->其它顺序检验,最先匹配的允许或禁止权限被应用。
- stat.S_IXOTH: 其他用户有执行权0o001
- stat.S_IWOTH: 其他用户有写权限0o002
- stat.S_IROTH: 其他用户有读权限0o004
- stat.S_IRWXO: 其他用户有全部权限(权限掩码)0o007
- stat.S_IXGRP: 组用户有执行权限0o010
- stat.S_IWGRP: 组用户有写权限0o020
- stat.S_IRGRP: 组用户有读权限0o040
- stat.S_IRWXG: 组用户有全部权限(权限掩码)0o070
- stat.S_IXUSR: 拥有者具有执行权限0o100
- stat.S_IWUSR: 拥有者具有写权限0o200
- stat.S_IRUSR: 拥有者具有读权限0o400
- stat.S_IRWXU: 拥有者有全部权限(权限掩码)0o700
- stat.S_ISVTX: 目录里文件目录只有拥有者才可删除更改0o1000
- stat.S_ISGID: 执行此文件其进程有效组为文件所在组0o2000
- stat.S_ISUID: 执行此文件其进程有效用户为文件所有者0o4000
- stat.S_IREAD: windows下设为只读
- stat.S_IWRITE: windows下取消只读
- 终止当前进程:
os.exit()
- 获取文件大小:
os.path.getsize(path)
- 创建空文件:
os.mknod("test.txt")
直接打开一个文件,如果文件不存在则创建文件:
fp = open("test.txt",w)
- 关于open 模式:
- w 以写方式打开,
- a 以追加模式打开 (从 EOF 开始, 必要时创建新文件)
- r+ 以读写模式打开
- w+ 以读写模式打开 (参见 w )
- a+ 以读写模式打开 (参见 a )
- rb 以二进制读模式打开
- wb 以二进制写模式打开 (参见 w )
- ab 以二进制追加模式打开 (参见 a )
- rb+ 以二进制读写模式打开 (参见 r+ )
- wb+ 以二进制读写模式打开 (参见 w+ )
- ab+ 以二进制读写模式打开 (参见 a+ )
- 操作
fp.read([size]) #size为读取的长度,以byte为单位
fp.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分
fp.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
fp.write(str) #把str写到文件中,write()并不会在str后加上一个换行符
fp.writelines(seq) #把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西。
fp.close() #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
fp.flush() #把缓冲区的内容写入硬盘
fp.fileno() #返回一个长整型的”文件标签“
fp.isatty() #文件是否是一个终端设备文件(unix系统中的)
fp.tell() #返回文件操作标记的当前位置,以文件的开头为原点
fp.next() #返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
fp.seek(offset[,whence]) #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了,whence可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
fp.truncate([size]) #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。
- 关于open 模式:
目录操作:
- os.mkdir(“file”) 创建目录
- 复制文件:
- shutil.copyfile(“oldfile”,”newfile”) oldfile和newfile都只能是文件
- shutil.copy(“oldfile”,”newfile”) oldfile只能是文件夹,newfile可以是文件,也可以是目标目录
- 复制文件夹:
- shutil.copytree(“olddir”,”newdir”) olddir和newdir都只能是目录,且newdir必须不存在
- 重命名文件(目录)
- os.rename(“oldname”,”newname”) 文件或目录都是使用这条命令
- 移动文件(目录)
- shutil.move(“oldpos”,”newpos”)
- 删除文件
- os.remove(“file”)
- 删除目录
- os.rmdir(“dir”)只能删除空目录
- shutil.rmtree(“dir”) 空目录、有内容的目录都可以删
- 转换目录
- os.chdir(“path”) 换路径
阅读全文
0 0
- Python 文件操作常用操作
- [python]python操作xml文件
- Python文件操作
- python文件目录操作
- Python文件操作
- Python文件操作
- python 文件操作
- python 文件操作
- Python 文件操作
- python 文件操作
- Python文件操作
- python 文件读写操作
- Python文件读写操作
- python文件目录操作
- Python的文件操作
- python常见文件操作
- python - 文件操作
- python文件操作
- 获取input原来的值,input还原
- 什么时候不应当使用虚函数
- NetCDF一维数据的写入
- spring注入bean进入工具类的静态方法
- 2017.10.22 Ardupilot开发者大会会议笔记,绝对干货满满!
- python-文件操作
- socket 实现简单的计算器
- 图解powerdesigner连接MySQL数据库
- 自定义动画之Drawable结合ProgressBar
- Java基础——集合
- 数组一些方法
- RabbitMQ应用实例Python版-工作队列
- 17.12.12
- Oracle异常整理