磁盘将数据写入各个扇区中,使数据分散在各个未使用的块上来储存数据。并用一套文件系统对数据进行管理,微观上,文件系统使用INode结构体来记录这些块区的地址以及数据的先后顺序,实现对这些乱序储存的数据管理。宏观上,为了方便用户的管理,使用路径字符串的方式来“描述”文件的位置,但这只是一种逻辑位置,并不存在此种数据上的层级关系,一个文件字符串在将会映射到一个的INode结构体中,再使用iNode结构体实现对数据的操作。
当对数据进行拷贝,跨分区的移动等涉及磁盘块上数据移动操作时,将需要进行文件IO操作,此时为了定位数据位置,宏观上,用户使用路径字符串的方式去寻找这些数据。此时,对文件的操作被封装成了对一个个路径字符串的操作。
默认为当前文件所处的目录,是工作目录路径,而不是这个文件的路径,文件路径为__file__
# 获取当前的工作目录 os.getcwd() os.path.dirname(__file__)
当我们使用相对路径指定文件的时, 默认的绝对路径是 “当前工作目录” + “文件路径”,而当前工作目录默认为这个文件所处的目录。我们可以将其指定到其他的目录中去
os.getcwd() # 获取当前路径 os.chdir("d:") # 改变这个工作目录当 d: 盘下, 根盘符开始,是绝对路径 os.chdir("config") # 这是一个相对路径,会在当前的工作目录下找 config 目录,然后切换当这个config目录中
os.mkdir(path) # path如果绝对路径,在这个绝对路径下创建,否则在当前工作目录下创建。 os.makedirs(path1/path2/path3/...) 创建多级目录 os.rmdir(path) # 删除目录 os.removedirs(path1/path2...) # 删除多级目录,每级目录必须为空才可以删除。 os.sep # 当前操作系统所使用的路径分隔符
遍历一个目录下的所有文件,可以使用walk遍历。walk使用深度遍历优先方式。
os.walk("path") # 依次递归遍历这个目录并返回一个生成器,每次一个三元组。 # 每次next返回的三元组 ("正在遍历目录路径", [子目录列表],[子文件列表] )
使用os.system(path) 可以执行这个可执行文件,例如,打开微信客户端,打开cmd命令行等
os.system("cmd") # 可以打开命令行终端,并可以实现交互 os.system("d:\python.exe ") # 绝对路径下使用搜寻可执行文件,存在就执行这个文件。
os.name() Windows是nt,Linux是Posix os.uname() *nix支持 os.platform() 平台架构win32(swindows),linux os.stat(path, dir_fd=None, follow_symlinks=True) path = 路径或者文件描述符 follow_symlinks = True 默认跟踪软链接, os.lstat() 同上,默认不跟踪软链接 os.chmod(path, mode, dir_fd=None, follow_symlinks=True) os.chown(path, uid, gid) os.getcwd() os.system() os.chdir() os.stat(".")
文件路径字符串作为一种特殊的字符串(作为文件的映射),需要根据文件的管理过程中的常用操作方式,提供一些方便的方法对这些路径字符串进行对应的操作,例如,拼接,分割,取父目录,取文件名等来实现文件的操作规则。
os.ltsep = "/" # 默认分割符号,不同的操作系统不同 os.path.abspath(path) os.path.relpath(path, start=os.curdir) # 从strat路径到path路径的相对路径表示方式。路径字符串游戏而已,实际路径不存在。 -------------------------------------------- os.path.basename(path) os.path.dirname(path) -------------------------------------------- os.path.commonpath(paths) # 返回最长的相同的父路径 os.path.commonprefix(list) # 从左到右最长的相同字符串 >>> os.path.commonprefix(['/usr/lib', '/usr/local/lib']) '/usr/l' # 共同的前缀,以字符串的方式进行计算。相同的字符均可。 >>> os.path.commonpath(['/usr/lib', '/usr/local/lib']) '/usr' # 共同的父目录字符串 -------------------------------------------- os.path.exists(path) # 判断这个路径是否在当前文件系统中存在,此时才会真实验证路径的存在性 # path还可以是一个数字,将作为文件描述符检测是否存在。 # 存在返回True, 不存在返回False os.path.lexists(path) # 是否存在这个 link 软链接文件 ------------------------------------------- os.path.expanduser(path) os.path.expandvars(path) ------------------------------------------- os.path.getatime(path) # 返回对应文件的最新的access time,不存在或者不可访问报错 os.path.getmtime(path) # 返回对应文件的最新的modify time,不存在或者不可访问报错 os.path.getctime(path) # 返回对应文件的最新的create time,不存在或者不可访问报错 os.path.getsize(path) # 获取文件 字节 长度.不存在或者不可访问报错 ------------------------------------------- os.path.isabs(path) # 判断是否为绝对路劲. posix 以根,windows 以磁盘盘符号 os.path.isfile(path) os.path.isdir(path) os.path.islink(path) ------------------------------------------ os.path.join(path, *paths) # 拼接字符串,POSIX和Windows默认拼接符不同 os.path.normcase(path) # Normalize the case of a pathname os.path.normpath(path) # 将路径字符串规范统一化,Windows会调用normcase(path) # 一些复杂的路径如 A//B, A/B/, A/./B and A/foo/../B 变成最简路径 A/B. os.path.samefile(path1, path2) # 判断两个路径是否指向同一个文件,根据指向同一个inode编号判断 os.path.sameopenfile(fp1, fp2) # 打开的是同一个文件返回True os.path.samestat(stat1, stat2) # 指向相同的文件返回True. os.path.split(path) # 分割父目录和基名 os.path.split("c:\\temp\\jdd\\ddd\\daa") # ('c:\\temp\\jdd\\ddd', 'daa') os.path.splitext(path) # 分割基名后缀, os.path.splitext("c:\\temp\\jdd\\ddd\\daa.tar") # ('c:\\temp\\jdd\\ddd\\daa', '.tar') #只有.bashrc 返回(.bashrc, "")
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理