Python中的os提供了非常丰富的方法用来处理文件和目录,下面我们将详细的介绍os相关的一些方法和函数:

os 路径相关的函数:

1.os.listdir(dirname):列出dirname目录下的目录和文件,需要注意的是传入的dirname是一个目录,而不是文件。

比如:print(os.listdir('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))就会报传入的目录无效,因为传入的是一个文件。

print(os.listdir(os.path.dirname(__file__))):列出当前文件所属目录下的所有文件和目录,使用列表的方式展示所有文件和目录

结果如下:['baidu.py', 'firefox.log', 'geckodriver.log', 'index.py', 'index1.py', 'index2.py', 'index3.py', 'index4.py']

2.os.getcwd():获得当前工作目录(获取的是目录,而不是具体的文件)

例如:当前的文件的绝对路径为:C:\\Python\test\index1.py

那么在index1.py中使用os.getcwd()的值为:C:\\Python\test

3.os.curdir:返回当前目录('.'),暂时还没有找到实际的意义

4.os.chdir(dirname):改变工作目录到dirname目录
5.os.path.isdir(name):判断name是不是一个目录,如果name不是目录就返回false,否则就为true

例如:print(os.listdir('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:False

6.os.path.isfile(name):判断name是不是一个文件,如果是目录或者不存在name这个文件返回false,否则为true

例如:print(os.listdir('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:True

7.os.path.exists(name):判断是否存在文件或目录name,存在则返回true
8.os.path.getsize(name):获得文件大小,单位为字节B

如果name是目录,则看以下的例子

如果是文件,则有两种方式,如果指定了具体的文件,则返回文件大小

例如:print(os.path.getsize('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))【指定具体的文件baidu.py】

返回结果:1220【返回的是baidu.py这个文件的实际文件大小】

例如:print(os.path.getsize('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex'))【未指定具体的文件,只指定了目录】

返回结果:4096【返回的是baidu.py这个文件所占的磁盘空间大小】

从这里我们就延伸出文件的大小以及文件所占空间的区别:

一个文件或文件夹属性中的“大小(Size)”和“占用空间(Size on disk)”通常不相互匹配。“大小”的值表示文件实际大小的字节数,而“占用空间”的值表示文件占用硬盘空间大小的字节数。

这种差异来自文件系统在驱动器上存储的文件的方式。为了减少使用的地址数量,文件系统把一定数量的字节当成簇。根据不同的文件系统,常见的簇大小可以从2KB的到32KB。一个被写入到磁盘的文件需要占用若干个不相连的簇,而无论文件的实际大小。因此,一个1KB的文件,保存在一个簇大小为2KB的文件系统将占用2KB,但保存在一个簇大小为32KB的文件系统,它会占用32KB。也就是说,一个33KB的文件将占用17个2KB的簇(34KB)或2个32KB的簇(64KB)。

基于上述的讨论,你会期望占用空间的大小会比实际大小更大,但是多出的部分不会超过一个簇的大小。在查看一个有很多文件的文件夹时,这种差异可能会更大,因为每个单独文件浪费的空间加起来会体现在文件夹上。

9.os.path.abspath(name):获得绝对路径

例如:print(os.path.abspath('baidu.py'))

返回结果:C:\Users\xiong\Desktop\其他\自动化\CQ_Credit\testindex\baidu.py

10.os.path.normpath(path):规范path字符串形式

11.os.path.split(name):分割文件名与目录(事实上,如果你完全使用目录,它也会将最后一个目录作为文件名而分离,同时它不会判断文件或目录是否存在)

例如:print(os.path.split('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex', 'baidu.py')【使用元组的方式展示结果】

特例:print(os.path.split('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex'))

返回结果:('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit', 'testindex')将最后一个目录作为了文件名,与前面的目录分开了

12.os.path.splitext():分离文件名与扩展名

例如:print(os.path.splitext('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu', '.py')前面为文件名,后面为文件后缀

13.os.path.join(path,name):连接目录与文件名或目录

14.os.path.basename(path):返回文件名

例如:print(os.path.basename('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:baidu.py 【只返回当前文件】

15.os.path.dirname(path):返回文件路径 目录

例如:print(os.path.dirname('C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex/baidu.py'))

返回结果:C:/Users/xiong/Desktop/其他/自动化/CQ_Credit/testindex【返回的是目录】

1、os.path方法

通过传入需要遍历的目录,列出目录下的所有文件并统计文件数,os提供的path模块能对目录非常灵活的操作。

import os,sys
def listdir(dir,file):
file.write(dir + '\n')
fielnum = 0
list = os.listdir(dir) #列出目录下的所有文件和目录
for line in list:
filepath = os.path.join(dir,line)
if os.path.isdir(filepath): #如果filepath是目录,则再列出该目录下的所有文件
myfile.write(' ' + line + '\\'+'\n')
for li in os.listdir(filepath):
myfile.write(' '+li + '\n')
fielnum = fielnum + 1
elif os.path: #如果filepath是文件,直接列出文件名
myfile.write(' '+line + '\n')
fielnum = fielnum + 1
myfile.write('all the file num is '+ str(fielnum))
dir = raw_input('please input the path:')
myfile = open('list.txt','w')

2、os.walk方法

os模块提供的walk方法很强大,能够把给定的目录下的所有目录和文件遍历出来。

方法:os.walk(path),遍历path,返回一个对象,他的每个部分都是一个三元组,('目录x',[目录x下的目录list],目录x下面的文件)

import os
def walk_dir(dir,fileinfo,topdown=True):
for root, dirs, files in os.walk(dir, topdown):
for name in files:
print(os.path.join(name))
fileinfo.write(os.path.join(root,name) + '\n')
for name in dirs:
print(os.path.join(name))
fileinfo.write(' ' + os.path.join(root,name) + '\n')
dir = raw_input('please input the path:')
fileinfo = open('list.txt','w')
walk_dir(dir,fileinfo)

参考地址1:http://blog.csdn.net/smf0504/article/details/54021857

参考地址2:http://www.cnblogs.com/yigehundan/p/6379586.html

Python学习笔记之os模块的更多相关文章

  1. Python学习笔记:os模块和sys模块

    os模块 os.path.driname(path):返回当前路径的上一级路径字符串. os.path.basename(path):返回当前路径的目录名(文件夹名)或文件名(全称). os.path ...

  2. 吴裕雄--python学习笔记:os模块的使用

    在自动化测试中,经常需要查找操作文件,比如说查找配置文件(从而读取配置文件的信息),查找测试报告(从而发送测试报告邮件),经常要对大量文件和大量路径进行操作,这就依赖于os模块. 1.当前路径及路径下 ...

  3. 吴裕雄--python学习笔记:os模块函数

    os.sep:取代操作系统特定的路径分隔符 os.name:指示你正在使用的工作平台.比如对于Windows,它是'nt',而对于Linux/Unix用户,它是'posix'. os.getcwd:得 ...

  4. python 3.x 学习笔记8 (os模块及xml修改)

    1.os模块操作 os.getcwd():                                       # 查看当前所在路径. os.listdir(path):            ...

  5. Python+Selenium学习笔记7 - os模块

    os模块是关于文件/目录方面的 导入语法 import os 相关方法 path.abspath()   用来获取当前路径下的文件 os.path.abspath('checkbox.html')  ...

  6. python学习笔记之常用模块(第五天)

    参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...

  7. python学习笔记(九)、模块

    1 模块 使用import 语句从外部导入模块信息,python提供了很大内置模块.当你导入模块时,你会发现其所在目录中,除源代码文件外,还新建了一个名为__pycache__的子目录(在较旧的Pyt ...

  8. Python学习笔记十_模块、第三方模块安装、模块导入

    一.模块.包 1.模块 模块实质上就是一个python文件.它是用来组织代码的,意思就是把python代码写到里面,文件名就是模块的名称,test.py test就是模块的名称 2.包 包,packa ...

  9. Python学习笔记4-os,sys模块

    一.os模块 import os print(os.getcwd())#取当前工作目录 os.chmod("/usr/local",7)#给文件/目录加权限 print(os.ch ...

随机推荐

  1. 俄罗斯最新开源的牛掰数据库ClickHouse

    ClickHouse是俄罗斯最近刚刚开源的用于数据库管理系统能够实时生成分析数据报告,性能非常强悍! 使用SQL查询. 他拥有切割你的数据更多的新方法 ClickHouse的性能超过同类市场上目前用于 ...

  2. JavaWeb -- Struts2 构建视图:标签和结果, UI组件标签

    1. 示例 action 注入数据 和 处理action /** * OgnlAction */ public class UiAction extends ActionSupport { priva ...

  3. 运行jar_测试代码

    1.Eclipse 将 工程 导出成 jar Eclipse --> Export... --> 界面中树状图形中选择" Java下的'JAR file' "(不知道这 ...

  4. docker 跨主机网络:overlay 简介

    简介 docker 在早前的时候没有考虑跨主机的容器通信,这个特性直到 docker 1.9 才出现.在此之前,如果希望位于不同主机的容器能够通信,一般有几种方法: 使用端口映射:直接把容器的服务端口 ...

  5. void与其他类型的转化

    #include<stdio.h> void f(void *a) { printf("%d\n",a); } int main() { int b=10; f(b); ...

  6. spring: spittr实例 构建简单的web应用

    我的环境是: jdk8, spirng4 之前照者书上说的做了,不得成功,于是网上百度,不得其然. 后来看到一篇文章,甚是所感.https://segmentfault.com/q/101000000 ...

  7. 【Demo】CSS3 2D转换

    2D转换transform 2D变换方法: translate() 根据左(X轴)和顶部(Y轴)位置给定的参数,从当前元素位置移动. div { transform: translate(50px,1 ...

  8. git rm -r --cached 去掉已经托管在git上的文件

    1.gitignore文件 在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法.这个文件每一行保存了一个匹配的规则例如: # 此为注释 – 将被 ...

  9. MongoCola使用教程 1 - MongoDB的基本操作和聚合功能---Mongdb客户端软件操作说明

    前言 在开始正文之前,感谢博客园的Nosql爱好者对于MongoCola工具的试用(使用).特别感谢 呆呆 这位朋友的Bug报告,让我纠正了一个很严重的Bug.同时也感谢以前的多个网友在博客留言中给我 ...

  10. [eShopOnContainers 学习系列] - 02 - vs 2017 开发环境配置

    [eShopOnContainers 学习系列] - 02 - vs 2017 开发环境配置 https://github.com/dotnet-architecture/eShopOnContain ...