
作者:小伍哥
来源:AI入门学习
os,语义操作系统,所以该模块就是操作系统相关的功能了,用于处理文件和目录这些我们日常手动需要做的操作,比如新建文件夹、获取文件列表、删除某个文件、获取文件大小、重命名文件、获取文件修改时间等,该模块就包含了大量的操作系统操作函数,精选常用的进行解析,希望对大家有所帮助。
os下面有很多函数,调用方式一般为os.name,其中比较特殊的是Path,Path模块是OS的一个子模块,下面又有很多的函数,调用方式一般为os.path.isfile。刚接触的可能不大明白,需要注意下。
#加载
import os
#查看os下的函数
print(dir(os))
#查看os.path下的函数
print(dir(os.path))
01、os.name()
描述:显示当前使用的平台,'nt'表示Windows,'posix' 表示Linux
语法:os.name
os.name
'nt'
02、os.getcwd()
描述:返回当前进程的工作目录。
语法:os.getcwd()
os.getcwd()
'C:\\Users\\wuzhengxiang'
03、os.chdir()
描述:改变当前工作目录到指定的路径。
语法:os.chdir(path)
#查看当前目录os.getcwd()
'C:\\Users\\wuzhengxiang'#重新设置当前工作空间
os.chdir('C:/Users/wuzhengxiang/Desktop/股票数据分析')
#再次查看当前目录,已经变成新的了
os.getcwd()
'C:\\Users\\wuzhengxiang\\Desktop\\股票数据分析'
04、os.makedirs()
描述:方法用于递归创建目录。像 mkdir(), 但创建的所有intermediate-level文件夹需要包含子目录。
语法:os.makedirs(path, mode=0o777)
os.makedirs('C:/Users/wuzhengxiang/Desktop/股票数据分析/1122', mode=0o777)
05、os.mkdir()
描述:以数字权限模式创建目录。默认的模式为 0777 (八进制)。
语法:os.mkdir(path[, mode])
#创建新的目2233
os.mkdir('C:/Users/wuzhengxiang/Desktop/股票数据分析/2233', mode=0777 )
06、os.listdir()
描述:列出目录下的所有文件和文件夹
语法:os.listdir(path)
os.listdir('C:/Users/wuzhengxiang/Desktop/股票数据分析')
['ETF研究.py', 'foo.txt', 'pi.txt', 'render.html']
os.listdir('.')
['ETF研究.py', 'foo.txt', 'pi.txt', 'render.html']
07、os.remove()
描述:用于删除指定路径的文件。如果指定的路径是一个目录,将抛出OSError。
语法:os.remove(path)
os.remove('C:/Users/zhengxiang.wzx/Desktop/timg.jpg')
08、os.rename()
描述:命名文件或目录,能对相应的文件进行重命名
语法:os.rename(src, dst)
参数
#空间设置
data_path = 'C:/Users/zhengxiang.wzx/Desktop/微博情绪识别'
os.chdir(data_path)#设置工作空间
os.getcwd()
'C:\\Users\\zhengxiang.wzx\\Desktop\\微博情绪识别'
os.rename("图片下载.py","图片下载1.py")
09、os.renames()
描述:用于递归重命名目录或文件。类似rename()。既可以重命名文件, 也可以重命名文件的上级目录名
语法:os.renames(old, new)
参数:
os.chdir('C:/Users/wuzhengxiang/Desktop/Python知识点总结')
os.getcwd()
#文件夹和文件同时命名
os.renames("test/Python 63个内置函数详解.py","test2/内置函数详解.py")
os.listdir()
['kaggle',
'test2',
'股票分析',
'课程资源'
10、os.linesep()
描述:当前平台用于分隔(或终止)行的字符串。它可以是单个字符,如 POSIX 上是 '\n',也可以是多个字符,如 Windows 上是 '\r\n'。在写入以文本模式(默认模式)打开的文件时,请不要使用 os.linesep 作为行终止符,请在所有平台上都使用一个 '\n' 代替。
语法:os.linesep
os.linesep
'\r\n'
11、os.pathsep()
描述:操作系统通常用于分隔搜索路径(如 PATH)中不同部分的字符,如 POSIX 上是 ':',Windows 上是 ';'。在 os.path 中也可用。
语法:os.pathsep
os.pathsep
';'
12、os.close()
描述:关闭指定的文件描述符 fd
语法:os.close(fd)
fd = os.open( "foo.txt", os.O_RDWR|os.O_CREAT )
os.write(fd, bytes("This is test", encoding = "utf8"))
os.close( fd )
13、os.stat()
描述:获取文件或者目录信息
语法:os.stat(path)
os.stat('C:/Users/wuzhengxiang/Desktop/股票数据分析\\pi.txt')
os.stat_result(st_mode=33206, st_ino=22236523160361562, st_dev=2419217970, st_nlink=1
, st_uid=0, st_gid=0, st_size=53, st_atime=1589638199, st_mtime=1589638199, st_ctime=1581868007)
14、os.sep()
描述:显示当前平台下路径分隔符,在 POSIX 上是 '/',在 Windows 上是是 '\\'
语法:os.sep
os.sep'
\\'
15、os.path.abspath()
描述:返回文件的绝对路径
语法:os.path.abspath(path)
#Excel文件
os.path.abspath('all_data.xlsx')
'C:\\Users\\zhengxiang.wzx\\all_data.xlsx'
#图片文件
os.path.abspath('IMG_7358.JPG')
'C:\\Users\\zhengxiang.wzx\\IMG_7358.JPG'
16、os.path.basename()
描述:返回文件名,纯粹字符串处理逻辑,路径错误也可以
语法:os.path.basename(path)
os.path.basename('C:\\Users\\zhengxiang.wzx\\all_data.xlsx')
'all_data.xlsx'
17、os.path.commonprefix()
描述:返回list(多个路径)中,所有path共有的最长的路径
语法:os.path.commonprefix(list)
os.path.commonprefix(['http://c.biancheng.net/python/aaa', 'http://c.biancheng.net/shell/'])'http://c.biancheng.net/'os.path.commonprefix(['http://bianc/python/aaa', 'http://c.biancheng.net/shell/'])'http://'
18、os.path.dirname()
描述:返回文件路径
语法:os.path.dirname(path)
os.path.dirname('C://my_file.txt')
'C://'
os.path.dirname('C://python//my_file.txt')
'C://python'
19、os.path.exists()
描述:如果路径 path 存在,返回 True;如果路径 path 不存在,返回 False。
语法:os.path.exists(path)
os.path.exists('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
True
os.path.exists('C:/Users/wuzhengxiang/Desktop/股票数据分析/')
True
os.path.exists('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi_01.txt')
Fals
20、os.path.lexists()
描述:路径存在则返回True,路径损坏也返回True, 不存在,返回 False。
语法:os.path.lexists
os.path.lexists('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
True
os.path.lexists('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi_01.txt')
False
21、os.path.expanduser()
描述:把path中包含的"~"和"~user"转换成用户目录
语法:os.path.expanduser(path)
os.path.expanduser('~/wuzhengxiang/Desktop/股票数据分析/')
'C:\\Users\\wuzhengxiang/wuzhengxiang/Desktop/股票数据分析/'
22、os.path.expandvars()
描述:根据环境变量的值替换path中包含的"$name"和"${name}"
语法:os.path.expandvars(path)
os.environ['KITTIPATH'] = 'D:/thunder'
path = '$KITTIPATH/train/2011_09_26_drive_0001_sync/proj_depth/velodyne_raw/image_02/0000000013.png'
os.path.expandvars(path)
'D:/thunder/train/2011_09_26_drive_0001_sync/proj_depth/velodyne_raw/image_02/0000000013.png'
23、os.path.getatime()
描述:返回最近访问时间(浮点型秒数),从新纪元到访问时的秒数。
语法:os.path.getatime(path)
os.path.getatime('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
1589638199.1343248
24、os.path.getmtime()
描述:返回最近文件修改时间,从新纪元到访问时的秒数。
语法:os.path.getmtime(path)
os.path.getmtime('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
1583069050.8148942
25、os.path.getctime()
描述:返回文件 path 创建时间,从新纪元到访问时的秒数。
语法:os.path.getctime(path)
os.path.getctime('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
1581868007.6123319
26、os.path.getsize()
描述:返回文件大小,如果文件不存在就返回错误
语法:os.path.getsize(path)
os.path.getsize('C:/Users/wuzhengxiang/Desktop/股票数据分析/test.gif')
1128677
27、os.path.isabs()
描述:判断是否为绝对路径,也就是说在WIndow系统下,如果输入的字符串以" / "开头,os.path.isabs()就会返回True
语法:os.path.isabs(path)
os.path.isabs('D:/thunder')
True
os.path.isabs('D:\thunder')
False
os.path.isabs('D:\\thunder')
True
28、os.path.isfile()
描述:判断路径是否为文件
语法:os.path.isfile(path)
#文件不存在 返回False
os.path.isfile("C:/Users/wuzhengxiang/Desktop/股票数据分析/pi_01.txt")
False
os.path.isfile("C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt")
True#不是文件 返回Falseo
s.path.isfile("C:/Users/wuzhengxiang/Desktop/股票数据分析/")
False
29、os.path.isdir()
描述:判断路径是否为目录
语法:os.path.isdir(path)
os.path.isdir('C:/Users/wuzhengxiang/Desktop/股票数据分析')
True
os.path.isdir('C:/Users/wuzhengxiang/Desktop/股票数据分析1')
False
os.path.isdir('C:/Users/wuzhengxiang/Desktop/股票数据分析/pi.txt')
False
30、os.path.join()
描述:把目录和文件名合成一个路径,1.如果各组件名首字母不包含’/’,则函数会自动加上,2.如果有一个组件是一个绝对路径,则在它之前的所有组件均会被舍弃,3.如果最后一个组件为空,则生成的路径以一个’/’分隔符结尾
语法:os.path.join(path1[, path2[, ...]])
os.path.join('C:/Users','wuzhengxiang/Desktop/','股票数据分析')
'C:/Users\\wuzhengxiang/Desktop/股票数据分析'
Path1 = 'home'
Path2 = 'develop'
Path3 = 'code'
Path10 = Path1 + Path2 + Path3
Path20 = os.path.join(Path1,Path2,Path3)
print ('Path10 = ',Path10)
print ('Path20 = ',Path20)
Path10 = homedevelopcode
Path20 = home\develop\code
31、os.path.normcase()
描述:转换path的大小写和斜杠
语法:os.path.normcase(path)
os.path.normcase('D:\Python\test\data.txt')
'd:\\python\test\\data.txt'
os.path.normcase('c:/WINDOWS\\system64\\')
'c:\\windows\\system64\\'
32、os.path.normpath()
描述:规范path字符串形式
语法:os.path.normpath(path)
os.path.normpath('c://windows\\System32\\../Temp/')
'c:\\windows\\Temp'
33、os.path.realpath()
描述:返回path的真实路径
语法:os.path.realpath(path)
os.path.relpath('C:\\Users\\Administrat\\代码TRY\\test.ipynb', '代码TRY')
'..\\..\\..\\..\\Administrat\\代码TRY\\test.ipynb'
34、os.path.relpath()
描述:返回从当前目录或 start 目录(可选)到达 path 之间要经过的相对路径。这仅仅是对路径的计算,不会访问文件系统来确认 path 或 start 的存在性或属性。
语法:os.path.relpath(path[, start])
os.path.relpath('C:/Users/wuzhengxiang/Desktop/股票数据分析\\test.gif')
'test.gif'
35、os.path.samefile( )
描述:判断目录或文件是否相同
语法:os.path.samefile(path1, path2)
os.path.samefile('C:\\Users', 'C:\\Users')True
os.path.samefile('C:\\Users', 'C:/Users')True
os.path.samefile('C:\\Users', 'C:/Users/wuzhengxiang')False
36、os.path.split()
描述:把路径分割成 dirname 和 basename,返回一个元组
语法:os.path.split(path)
os.path.split('D:\Python\test\data.txt')
('D:\\Python\test', 'data.txt')
37、os.path.splitdrive()
37、os.path.splitdrive()
描述:一般用在 windows 下,返回驱动器名和路径组成的元组
语法:os.path.splitdrive(path)
os.path.splitdrive('C:/Users/zhengxiang.wzx/IMG_7358.JPG')
('C:', '/Users/zhengxiang.wzx/IMG_7358.JPG')
38、os.path.splitext()
描述:分割路径,返回路径名和文件扩展名的元组
语法:os.path.splitext(path)
os.path.splitext('C:/Users/zhengxiang.wzx/IMG_7358.JPG')
('C:/Users/zhengxiang.wzx/IMG_7358', '.JPG')
39、os.path.walk()
描述:遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数
语法:os.path.walk(path, visit, arg)
list(os.walk(abs_cur_dir))
[('C:/Users/wuzhengxiang/Desktop/股票数据分析',
['1122'],
['ETF研究.py', 'foo.txt', 'pi.txt', 'render.html', 'test.gif']),
('C:/Users/wuzhengxiang/Desktop/股票数据分析\\1122', [], [])]
#穷举遍历一个文件夹里面的所有文件,并获取文件的目录名
abs_cur_dir ='C:/Users/wuzhengxiang/Desktop/股票数据分析'
file_url=[]
for dirs,folders,files in os.walk(abs_cur_dir):
for i in files:
file_url.append(os.path.join(dirs,i))
file_url
['C:/Users/wuzhengxiang/Desktop/股票数据分析\\ETF研究.py',
'C:/Users/wuzhengxiang/Desktop/股票数据分析\\foo.txt',
'C:/Users/wuzhengxiang/Desktop/股票数据分析\\pi.txt',
'C:/Users/wuzhengxiang/Desktop/股票数据分析\\render.html',
'C:/Users/wuzhengxiang/Desktop/股票数据分析\\test.gif']
#pathlib也能实现类似的
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
CDA 数据分析师:善用 Power BI 索引列,提升数据处理与分析效率 在 Power BI 数据分析流程中,“数据准备” 是决定后续分析质量 ...
2025-08-18CDA 数据分析师:巧用 SQL 多个聚合函数,解锁数据多维洞察 在企业数据分析场景中,单一维度的统计(如 “总销售额”“用户总数 ...
2025-08-18CDA 数据分析师:驾驭表格结构数据的核心角色与实践应用 在企业日常数据存储与分析场景中,表格结构数据(如 Excel 表格、数据库 ...
2025-08-18PowerBI 累计曲线制作指南:从 DAX 度量到可视化落地 在业务数据分析中,“累计趋势” 是衡量业务进展的核心视角 —— 无论是 “ ...
2025-08-15Python 函数 return 多个数据:用法、实例与实战技巧 在 Python 编程中,函数是代码复用与逻辑封装的核心载体。多数场景下,我们 ...
2025-08-15CDA 数据分析师:引领商业数据分析体系构建,筑牢企业数据驱动根基 在数字化转型深化的今天,企业对数据的依赖已从 “零散分析” ...
2025-08-15随机森林中特征重要性(Feature Importance)排名解析 在机器学习领域,随机森林因其出色的预测性能和对高维数据的适应性,被广 ...
2025-08-14t 统计量为负数时的分布计算方法与解析 在统计学假设检验中,t 统计量是常用的重要指标,其分布特征直接影响着检验结果的判断。 ...
2025-08-14CDA 数据分析师与业务数据分析步骤 在当今数据驱动的商业世界中,数据分析已成为企业决策和发展的核心驱动力。CDA 数据分析师作 ...
2025-08-14前台流量与后台流量:数据链路中的双重镜像 在商业数据分析体系中,流量数据是洞察用户行为与系统效能的核心依据。前台流量与 ...
2025-08-13商业数据分析体系构建与 CDA 数据分析师的协同赋能 在企业数字化转型的浪潮中,商业数据分析已从 “可选工具” 升级为 “核 ...
2025-08-13解析 CDA 数据分析师:数据时代的价值挖掘者 在数字经济高速发展的今天,数据已成为企业核心资产,而将数据转化为商业价值的 ...
2025-08-13解析 response.text 与 response.content 的核心区别 在网络数据请求与处理的场景中,开发者经常需要从服务器返回的响应中提取数 ...
2025-08-12MySQL 统计连续每天数据:从业务需求到技术实现 在数据分析场景中,连续日期的数据统计是衡量业务连续性的重要手段 —— 无论是 ...
2025-08-12PyTorch 中 Shuffle 机制:数据打乱的艺术与实践 在深度学习模型训练过程中,数据的呈现顺序往往对模型性能有着微妙却关键的影响 ...
2025-08-12Pandas 多列条件筛选:从基础语法到实战应用 在数据分析工作中,基于多列条件筛选数据是高频需求。无论是提取满足特定业务规则的 ...
2025-08-12人工智能重塑 CDA 数据分析领域:从工具革新到能力重构 在数字经济浪潮与人工智能技术共振的 2025 年,数据分析行业正经历着前所 ...
2025-08-12游戏流水衰退率:计算方法与实践意义 在游戏行业中,流水(即游戏收入)是衡量一款游戏商业表现的核心指标之一。而游戏流水衰退 ...
2025-08-12CDA 一级:数据分析入门的基石 在当今数据驱动的时代,数据分析能力已成为职场中的一项重要技能。CDA(Certified Data Anal ...
2025-08-12破解游戏用户流失困局:从数据洞察到留存策略 在游戏行业竞争白热化的当下,用户流失率已成为衡量产品健康度的核心指标。一款游 ...
2025-08-11