os模块的使用方法详解
os模块
os模块负责程序与操作系统的交互,提供了访问操作系统底层的接口;即os模块提供了非常丰富的方法用来处理文件和目录。
使用的时候需要导入该模块:import os
常用方法如下:
|
方法名 |
作用 |
|
os.remove(‘path/filename’) |
删除文件 |
|
os.rename(oldname, newname) |
重命名文件 |
|
os.walk() |
生成目录树下的所有文件名 |
|
os.chdir('dirname') |
改变目录 |
|
os.mkdir/makedirs('dirname') |
创建目录/多层目录 |
|
os.rmdir/removedirs('dirname') |
删除目录/多层目录 |
|
os.listdir('dirname') |
列出指定目录的文件 |
|
os.scandir() |
和listdir相近的功能,列出指定目录的文件 Python 官方推荐 |
|
os.getcwd() |
取得当前工作目录 |
|
os.chmod() |
改变目录权限 |
|
os.path.basename(‘path/filename’) |
去掉目录路径,返回文件名 |
|
os.path.dirname(‘path/filename’) |
去掉文件名,返回目录路径 |
|
os.path.join(path1[,path2[,...]]) |
将分离的各部分组合成一个路径名 |
|
os.path.split('path') |
返回( dirname(), basename())元组 |
|
os.path.splitext() |
返回 (filename, extension) 元组 |
|
os.path.getatime\ctime\mtime |
分别返回最近访问、创建、修改时间 |
|
os.path.getsize() |
返回文件大小 |
|
os.path.exists() |
是否存在 |
|
os.path.isabs() |
是否为绝对路径 |
|
os.path.isdir() |
是否为目录 |
|
os.path.isfile() |
是否为文件 |
遍历所有文件及文件夹
获得当前python程序运行路径
import os
print(os.getcwd()) # 输出当前代码所在模块的路径#
/Users/running/PycharmProjects/chapter04/novel
切换目录到chapter03项目下:
os.chdir('/Users/running/PycharmProjects/chapter03')
查看当前目录下的所有文件和文件夹,并判断是否是文件和文件夹
import os
files = os.listdir()
for file in files:
print(file, os.path.isdir(file),
os.path.isfile(file))
输出结果:

或者使用:
forfileinos.scandir():
print(file.name, file.path,
file.is_dir())
可以调用file.stat()获取更加详细的文件信息。如:

其中:
st_size:文件的体积大小(单位:bytes),除以1024就是KB
st_atime:文件的最近访问时间
st_mtime:文件的最近修改时间
st_ctime:Windows下表示创建时间
案例1:
1. 键盘输入一个路径
2. 统计该路径下的文件和文件夹,以及分别的数量
3. 统计当前路径下包含文件名称中包含demo的文件数量,注意不区分大小写
import ospath = input('输入要查询的路径:')
os.chdir(path)
file_list = []
dir_list = []
for file inos.scandir():
if file.is_dir():
dir_list.append(file.name)
else:
file_list.append(file.name)
print("文件夹的总量是{},\n文件为别为{}".format(len(dir_list),dir_list))
print('{}'.format('-'*30))
print("文件总量是{},\n文件为别为{}".format(len(file_list),file_list))
print('{}'.format('-'*30))
python_list = []
for name in file_list:
if'demo'in name.lower():
python_list.append(name)
print('含有python单词的文件数量有{}个,\n文件分别为{}'.format(len(python_list),python_list))
如果要遍历一个目录下的所有子目录,里面指定的文件,我们可以通过递归函数遍历每个目录进行查找或者使用os.walk(),递归实现代码如下:
import os
import sys
from stat import *
defwalktree(top, callback):for f in os.listdir(top):
pathname = os.path.join(top, f)
try:
mode = os.stat(pathname, follow_symlinks=False).st_mode
except:
continueif S_ISDIR(mode):
# directory, recurse into it
walktree(pathname, callback)
else:
# file, whatever type, make the call back function
callback(pathname)
returndefprintfile(file):
print('get to', file)
if __name__ == '__main__':
if (os.path.isabs(sys.argv[1]) and
os.path.exists(sys.argv[1])):
walktree(sys.argv[1], printfile)
Python os模块的walk()函数,顾名思义,就是用来遍历目录树的,此函数可以很方便的遍历以输入的路径为root的所有子目录和其中的文件。
walk函数是一个Python生成器(generator),调用方式是在一个for...in...循环中,walk生成器每次返回的是一个含有3个元素的tuple,分别是 (dirpath, dirnames, filenames)
fordirpath, dirnames, filesinos.walk('./'):
print(dirpath,dirnames,files)
当然也可以使用glob模块快速实现,假设要获取主目录中所有的mp4文件:

此时使用glob更加方便
import glob
t_list = glob.glob('t*')
print(t_list) # 获取当前目录下t开头的文件,但是不能获取子文件夹里面的内容
Python的glob还支持**规则(从3.5开始),当**规则与另一个参数recursive=True配合的时候,可以深入的路径的子目录当中去匹配:
glob.glob('**') # 获取当前目录的文件和文件夹
glob.glob('**/') # 获取当前目录的文件夹# 如果**结合recursive=True使用,但是如果结合一个*则不能实现递归
glob.glob('**/',recursive=True) # 可以遍历出所有的子目录# 若要获取子目录中的文件则需要
glob.glob('**/*.mp4',recursive=True)
案例2:
1. 键盘输入一个路径
2. 搜索该路径下文件大小超过50M的zip文件
3. 搜索该路径下最后修改日期在30天前的文件
4. 打印显示2,3的文件
import os
import datetime
path = input('输入要查询的路径:')
os.chdir(path)
paths = glob.glob('**/*.zip',recursive = True)
forpathin paths:
file_size = os.stat(path).st_size/1024/1024
file_modify = datetime.datetime.fromtimestamp(os.stat(path).st_mtime)
days = (datetime.datetime.now() - file_modify).days
if (file_size > 50) and (days > 30):
print('压缩包的路径名称是:{},大小为{:.2f}MB,创建文件年份为:{}'.format(path,file_size,file_build_year))
批量操作文件及文件夹
创建文件夹和多层文件夹
import osifnotos.path.exists('新文件夹名'):
os.mkdir('新文件夹名')
# 创建多层文件夹
os.makedirs('第一层文件夹/第二层文件夹/第三层文件夹')
复制文件或者文件夹
复制、移动、删除文件夹需要借助另一个模块:shutil模块
# 首先导入模块import shutil
import os
shutil.copy('文件名', '目标文件夹') # 将文件复制到指定文件夹
shutil.copy('文件名', '目标文件夹/新文件名.txt') # 复制并重命名文件#如果复制的是文件夹
shutil.copytree('源文件夹','目标文件夹')
# 如果不想复制文件而是移动文件,可以使用过move方法 使用方法类似copy,也可以移动文件夹
shutil.move('文件名', '目标文件夹/')
shutil.move('源文件夹','目标文件夹/') # 文件夹后面记住最后加斜杠/# 若要删除文件夹
shutil.rmtree('文件夹名')
# 删除文件
os.remove('文件名')
案例3:
1. 键盘输入一个路径
2. 获取里面所有的mp4文件
3. 重命名mp4文件在每个文件前面添加前缀,前缀就是文件最后修改的年月日(如:2021-08-18_西游记01.mp4)
4. 新建文件夹:最新视频
5. 将重命名的视频批量移动到最新视频文件夹
import os
import datetime
import shutil
import glob
path = input('输入要查询的路径:')
os.chdir(path)
ifnotos.path.exists('最新视频'):
os.mkdir('最新视频')
for dirpath,dirnames,files inos.walk('./'):
for file inos.scandir(dirpath):
if file.name.endswith(".mp4"):
tm = datetime.datetime.fromtimestamp(file.stat().st_mtime)
new_file = str(tm.year)+'-'+str(tm.month)+'-'+str(tm.day)+'-'+file.name
os.rename(dirpath + '/' + file.name,new_file)
file_ls = glob.glob('*.mp4')
for name in file_ls:
shutil.move(name,'最新视频/')
print('over!!!')
os模块的使用方法详解的更多相关文章
- socket模块的getaddrinfo方法详解
getaddrinfo方法用于通过url解析dns import sys,socket def dns_resolver(url): result = socket.getaddrinfo(url, ...
- Python基础之 urllib模块urlopen()与urlretrieve()的使用方法详解。
Python urllib模块urlopen()与urlretrieve()的使用方法详解 1.urlopen()方法urllib.urlopen(url[, data[, proxies]]) ...
- python中requests库使用方法详解
目录 python中requests库使用方法详解 官方文档 什么是Requests 安装Requests库 基本的GET请求 带参数的GET请求 解析json 添加headers 基本POST请求 ...
- Python 字符串方法详解
Python 字符串方法详解 本文最初发表于赖勇浩(恋花蝶)的博客(http://blog.csdn.net/lanphaday),如蒙转载,敬请保留全文完整,切勿去除本声明和作者信息. ...
- PHP cURL应用实现模拟登录与采集使用方法详解
对于做过数据采集的人来说,cURL一定不会陌生.虽然在PHP中有file_get_contents函数可以获取远程链接的数据,但是它的可控制性太差了,对于各种复杂情况的采集情景,file_get_co ...
- Android ActionBar 关于tab的应用 以及 TabListener的方法详解
actionBar的tab标签应用以及TabListener的方法详解 package com.example.actionBarTest.actionBarTab; import android.a ...
- asp.net iis URLRewrite 实现方法详解
原文 asp.net iis URLRewrite 实现方法详解 实现非常简单首先你要在你的项目里引用两个dll:actionlessform.dll.urlrewriter.dll,真正实现重写的是 ...
- PHP cURL实现模拟登录与采集使用方法详解教程
来源:http://www.zjmainstay.cn/php-curl 本文将通过案例,整合浏览器工具与PHP程序,教你如何让数据 唾手可得 . 对于做过数据采集的人来说,cURL一定不会陌生.虽然 ...
- telnet 命令使用方法详解,telnet命令怎么用
telnet 命令使用方法详解,telnet命令怎么用? 文章类型:电脑教程 原创:天诺时空 什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协 ...
- php调用C代码的方法详解和zend_parse_parameters函数详解
php调用C代码的方法详解 在php程序中需要用到C代码,应该是下面两种情况: 1 已有C代码,在php程序中想直接用 2 由于php的性能问题,需要用C来实现部分功能 针对第一种情况,最合适的方 ...
随机推荐
- docker 中搭建 mysql pxc 集群
一.docker中创建pxc 容器 1.拉取PXC 镜像 pull docker pull percona/percona-xtradb-cluster:5.7.21 2.更改镜像名称为pxc t ...
- 前端常用函数(find、includes、filter、Set、forEach、map、some、every、findIndex、splice、reduce)
https://blog.csdn.net/qq_24280125/article/details/119275109 array.join(separator) .拼接返回字符串 参数 separa ...
- mysql 正则匹配不规则日期
where colum4 REGEXP "^[[:digit:]]{1}/[[:digit:]]{1}/[[:digit:]]{4}"=1 -- 2/3/2021 wher ...
- count(1) and count(*),count(字段)区别及效率比较
执行结果: count(1)和count(*)之间没有区别,因为count(*)count(1)都不会去过滤空值, count(字段) 会统计该字段在表中出现的次数,忽略字段为null 的情况.即不统 ...
- c++学习7 指针与数组
一 二维数组与数组指针的关系 二维数组名,代表的是第0行的行地址,"+1"是跳过一个行.而取" * "的话,则是在当前行地址基础上再取列地址,那么如果我们再取一 ...
- Arthas 查询服务器内存数据
1.打开Arthas所在位置 eg:/home 2.java -jar arthas-boot.jar 运行jar包 3.选择要执行的java jar包 eg : 1 4.执行查看命令vmtool - ...
- JAVA基础Day3-用户交互Scanner/顺序结构/选择结构/循环结构
一.用户交互Scanner JAVA提供了一个工具类,可以用来获取用户的输入. java.util.Scanner是Java5的新特征,可以通过Scanner类来获取用户的输入. 基本语法: Scan ...
- Bugku Log4j2 漏洞题目 解题参考
Log4j2 漏洞题目 题目地址 https://ctf.bugku.com/challenges/detail/id/340.html?page=1 二.攻击环境准备 需要一台linux云服务器,把 ...
- dotnet Core 在linux 下设置成Service
1.新建.service文件 cd /etc/systemd/system //进入改目录 touch Core.service // 新建Core服务文件 vi Core.service // 编辑 ...
- Spring Boot中使用过滤器和拦截器
过滤器(Filter)和拦截器(Interceptor)是Web项目中常用的两个功能,本文将简单介绍在Spring Boot中使用过滤器和拦截器来计算Controller中方法的执行时长,并且简单对比 ...