python模块--os模块

摘要:
Mod=viewthread&tid=45512&extra=page%3D1%26filter%3Dtypeid%26typeid%3D403˃˃操作系统。路径split#将路径名与文件名˃˃os分开。路径split#将文件名与后缀名˃˃os分开。路径拆分˃˃操作系统。路径拆分˃˃操作系统。path#拼接路径'/home/www/testdir'˃˃os。路径isdir#判断它是否为True˃˃os目录。路径isfile#判断是否为文件False˃˃[xforxinos.listdir('.')ifos.path.isdir]#列出当前目录中的所有目录˃˃[xfor xinos.llistdir()ifos/path.isfileandos.path.spiext[1]=='。py']#带有后缀的所有文件。当前目录os中的py。walk()方法遍历树操作系统。walk()方法遍历树操作系统。要遍历的walktop目录地址。获得三个元组。当topdown为true(默认值)时,首先从上到下遍历顶层目录。
打印文件的绝对路径:
os.path.abspath(__file__)

os.path.dirname("/root/python/test.py")   #只取目录名
'/root/python'

os.path.dirname(os.path.dirname("/root/python/test.py"))   
'/root'

import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
sys.path.append(BASE_DIR)
os模块中关于文件/目录常用的函数使用方法
函数名
使用方法
getcwd()返回当前工作目录
chdir(path)改变工作目录
listdir(path='.')列举指定目录中的文件名('.'表示当前目录,'..'表示上一级目录)
mkdir(path)创建单层目录,如该目录已存在抛出异常
makedirs(path)递归创建多层目录,如该目录已存在抛异常,注意'E:\a\b'和'E:\a\c'并不冲突
remove(path)删除文件
rmdir(path)删除单层目录,如该目录非空则抛出异常
removedirs(path)递归删除目录,从子目录到父目录逐层尝试删除,遇到目录非空则抛出异常
rename(old, new)将文件old重命名为new
system(command)运行系统的shell命令
walk(top)遍历top路径以下所有的子目录,返回一个三元组:(路径, [包含目录], [包含文件])
以下是支持路径操作中常用到的一些定义,支持所有平台
os.curdir指代当前目录('.')
os.pardir指代上一级目录('..')
os.sep输出操作系统特定的路径分隔符(Win下为'\',Linux下为'/')
os.linesep当前平台使用的行终止符(Win下为' ',Linux下为' ')
os.name指代当前使用的操作系统(包括:'posix',  'nt', 'mac', 'os2', 'ce', 'java')
 
os.path模块中关于路径常用的函数使用方法
函数名
使用方法
basename(path)去掉目录路径,单独返回文件名
dirname(path)去掉文件名,单独返回目录路径
join(path1[, path2[, ..]])将path1, path2各部分组合成一个路径名
split(path)分割文件名与路径,返回(f_path, f_name)元组。
splitext(path)分离文件名与扩展名,返回(f_name, f_extension)元组
getsize(file)返回文件的大小,单位是字节
getatime(file)返回文件最近的访问时间(浮点数,可用time.gmtime()或localtime()换算)
getctime(file)返回文件的创建时间(浮点数,可用time.gmtime()或localtime()换算)
getmtime(file)返回文件最新的修改时间(浮点数,可用time.gmtime()或localtime()换算)
以下为函数返回 True 或 False
exists(path)判断路径(目录或文件)是否存在
isabs(path)判断路径是否为绝对路径
isdir(path)判断路径是否存在且是一个目录
isfile(path)判断路径是否存在且是一个文件
islink(path)判断路径是否存在且是一个符号链接
ismount(path)判断路径是否存在且是一个挂载点
samefile(path1, paht2)判断path1和path2两个路径是否指向同一个文件
转自:https://fishc.com.cn/forum.php?mod=viewthread&tid=45512&extra=page%3D1%26filter%3Dtypeid%26typeid%3D403
 
>>> os.path.split('/etc/filebeat.yml')  #将路径名和文件名分开
('/etc', 'filebeat.yml')
>>> os.path.splitext('filebeat.yml')    # 将文件名和后缀名分开
('filebeat', '.yml')
>>> os.path.splitext('/etc/filebeat.yml')  
('/etc/filebeat', '.yml')

>>> os.path.join('/home/www','testdir')  #拼接路径
'/home/www/testdir'
>>> os.path.isdir('data')  # 判断是否是目录
True
>>> os.path.isfile('data')  #判断是否是文件
False
>>> [ x for x in os.listdir('.') if os.path.isdir(x)] #列出当前目录下的所有目录
>>> [x for x in os.listdir() if os.path.isfile(x) and os.path.splitext(x)[1] == '.py']  #当前目录下所有后缀为.py的文件

os.walk()方法 遍历树

os.walk()方法 遍历树
os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])

top 要遍历的目录的地址。得到3个元组,(dirpath,dirnames,filenames)
topdown 为True(默认)时,则优先遍历top目录,自上而下遍历。  否则优先遍历top的子目录(默认为开启),自下而上。

cd /root/test
# tree
.
|-- day1
|   |-- base.py
|   `-- day1.py
|-- day2
|   |-- day2.py
|   `-- day3
|       `-- a.txt
`-- test.py
directories, 5 files

>>> for paths,dirs,files in os.walk('/root/test'):
...      print(paths,dirs,files)
... 
/root/test ['day1', 'day2'] ['test.py']
/root/test/day1 [] ['day1.py', 'base.py']
/root/test/day2 ['day3'] ['day2.py']
/root/test/day2/day3 [] ['a.txt']


>>> for paths,dirs,files in os.walk('/root/test'):
...      print(paths)
... 
/root/test
/root/test/day1
/root/test/day2
/root/test/day2/day3
>>> for paths,dirs,files in os.walk('/root/test'):
...      print(dirs)    
... 
['day1', 'day2']
[]
['day3']
[]

>>> for paths,dirs,files in os.walk('/root/test'):
...      print(files)  
... 
['test.py']   
['day1.py', 'base.py']
['day2.py']
['a.txt']

>>> for paths,dirs,files in os.walk('/root/test'):
...      for f in files:
...              print(os.path.join(paths,f))    #得到所有目录及子目录下的文件
... 
/root/test/test.py
/root/test/day1/day1.py
/root/test/day1/base.py
/root/test/day2/day2.py
/root/test/day2/day3/a.txt

>>> for paths,dirs,files in os.walk('/root/test'):  
...      for d in dirs:
...              print(os.path.join(paths,d))     #得到所有的目录和子目录
... 
/root/test/day1
/root/test/day2
/root/test/day2/day3

os.walk()

免责声明:文章转载自《python模块--os模块》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇GHOST来进行备份和还原及菜单介绍使用mob提供的接口 查询IP对应的省市区信息(json对象转java对象)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

数据可视化:python matplotlib小试牛刀

Matplotlib有两个模块: 1) 绘图API:pyplot, 可这样导入import matplotlib.pyplot as plt    2)集成库:pylab, 是matplotlib Scipy Numpy的集成库 import pandas as pd import matplotlib.pyplot as plt from pylab i...

stacking算法原理及代码

stacking算法原理 1:对于Model1,将训练集D分为k份,对于每一份,用剩余数据集训练模型,然后预测出这一份的结果 2:重复上面步骤,直到每一份都预测出来。得到次级模型的训练集 3:得到k份测试集,平均后得到次级模型的测试集 4:对于Model2、Model3…..重复以上情况,得到M维数据 5:选定次级模型,进行训练预测,一般这最后一...

Linux 环境下 node 以及 jit 的简单环境配置说明

注意事项: 1. 注意这个包需要实时更新. 2. 更新时需要按照目录覆盖文件. 3. 谁负责谁治理的态度, 有更新,需要完整的进行覆盖安装. 建议先删除旧文件, 替换新文件. 4. 为了简单起见, 直接将部署文件放到了 /nodejs 这个目录下面 1. 解压缩文件到相应的路径, 如图示 建议方法为 直接将压缩包放到 / 目录下面 执行命令 t...

Python读写excel练习_去除excel中乱码行,并添加列

需求: 把app_student.xls里面的数据, 1、如果这一行数据里面有乱码(及包含?),那么就删掉 2、再加上一列,是否毕业 3、如果班级是天蝎座的话,毕业这一列写成毕业 4、其他班级的写成未毕业 原始数据: 实现: import xlrd,xlwt EXCEL_NAME = 'app_student.xls' def delete_messy_...

系统综合实践 第5次实践作业

目录 (一)Python容器文件配置 (二)程序的部署运行 (1)helloworld (2)日历输出 (3)数据库操作 (4)opencv (三)实验感想 作业地址 (一)Python容器文件配置 目录结构 Dockerfile FROM python MAINTAINER yezi WORKDIR /app #添加依赖文件 C...

Python学习————drf(三)

1 请求和响应 1.1 请求 # 请求对象 # from rest_framework.request import Request def __init__(self, request, parsers=None, authenticators=None, negotiator=None, parser_cont...