Python学习笔记(15)- os\os.path 操作文件
程序1
编写一个程序,统计当前目录下每个文件类型的文件数,程序实现如图:

import os def countfile(path):
dict1 = {} # 定义一个字典
all_files = os.listdir(path)
for each_file in all_files:
if os.path.isdir(os.path.join(path,each_file)):
dict1.setdefault('文件夹', 0)
# setdefault:如果字典中包含有给定键,
# 则返回该键对应的值,否则返回为该键设置的值。
dict1['文件夹'] += 1 # 参考以前分享的字典修改
else:
ext = os.path.splitext(each_file)[1]
# 分离文件名与扩展名,返回(f_name, f_extension)元组
dict1.setdefault(ext, 0)
dict1[ext] += 1
#print(dict1)
for each_type in dict1.keys():
print('该文件夹下共有【%s】类型的文件%d个'
% (each_type, dict1[each_type])) path = input('输入要统计的目录: ')
countfile(path)
程序2
编写一个程序,计算当前文件夹下所有文件的大小,程序实现如图:

import os def count_size(path):
filesize = {}
all_files = os.listdir(path)
for eachfile in all_files:
if os.path.isfile(os.path.join(path, eachfile)):
size = os.path.getsize(os.path.join(path, eachfile))
filesize[eachfile] = size
#filesize.setdefault(eachfile, os.path.getsize(os.path.join(path, eachfile))) for each in filesize.items():
print("%s【%sBytes】" % (each[0], each[1])) path = input('输入要统计的目录: ')
count_size(path)
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路径以下所有的子目录,返回一个三元组:(路径, [包含目录], [包含文件])【具体实现方案请看:第30讲课后作业^_^】 |
|
以下是支持路径操作中常用到的一些定义,支持所有平台 |
|
|
os.curdir |
指代当前目录('.') |
|
os.pardir |
指代上一级目录('..') |
|
os.sep |
输出操作系统特定的路径分隔符(Win下为'\\',Linux下为'/') |
|
os.linesep |
当前平台使用的行终止符(Win下为'\r\n',Linux下为'\n') |
|
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两个路径是否指向同一个文件 |
张老师提供咨询服务啦:-->点击查看 <--
往期回顾
Python学习笔记(3)-数据类型
Python学习笔记(8)-四个小程序
Python学习笔记(10)-回文联和统计入参
Python学习笔记(15)-文件
Python学习笔记(15)- os\os.path 操作文件的更多相关文章
- 吴裕雄--天生自然python学习笔记:Python3 OS 文件/目录方法
os 模块提供了非常丰富的方法用来处理文件和目录.常用的方法如下表所示: 序号 方法及描述 1 os.access(path, mode) 检验权限模式 2 os.chdir(path) 改变当前工作 ...
- python学习笔记:模块——os模块(操作文件/目录)
import os os.rename(old,new) #重命名文件或目录 os.remove(f)#删除文件 os.mkdir('china/beijing') #创建文件夹 os.makedir ...
- Python学习笔记3-文件的简单操作
Python中的文件操作 Python中文件打操作离不开两个模块 os 和 shutil os:操作文件.目录: Python os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话, ...
- python学习笔记(1)--遍历txt文件,正则匹配替换文字
遍历一个文件夹,把里面所有txt文件里的[]里的朗读时间删除,也就是替换为空. import os import re import shutil #os文件操作,re正则,shutil复制粘贴 pa ...
- Android(java)学习笔记167:Java中操作文件的类介绍(File + IO流)
1.File类:对硬盘上的文件和目录进行操作的类. File类是文件和目录路径名抽象表现形式 构造函数: 1) File(String pathname) Creat ...
- Android(java)学习笔记110:Java中操作文件的类介绍(File + IO流)
1.File类:对硬盘上的文件和目录进行操作的类. File类是文件和目录路径名抽象表现形式 构造函数: 1) File(String pathname) Creat ...
- Python学习笔记15—mysql的操作
安装 Python-MySQLdb pip install mysql-Python Python对mysql的操作 建立一个实验数据库demo mysql> create database d ...
- Python学习笔记-Day2-Python基础之字符串操作
字符串的常用操作包括但不限于以下操作: 字符串的替换.删除.截取.复制.连接.比较.查找.分割等 这里将对字符串的内置操作方法进行总结归纳,重点是以示例的方式进行展示. 使用type获取创建对象的类 ...
- python学习笔记15(面向对象编程)
虽然Python是解释性语言,但是它是面向对象的,能够进行对象编程. 一.如何定义一个类 在进行python面向对象编程之前,先来了解几个术语:类,类对象,实例对象,属性,函数和方法. 类是对现实世界 ...
- python学习笔记(十):操作excel
一.python操作excel,python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的 ...
随机推荐
- Spring Cloud Eureka 集群搭建 - 以及发现一个 “直觉BUG”
首先解释一下标题所说的“直觉BUG”,这个是我自己的定义.就是我们直觉上认为这是一个BUG,是一个错误,而实际并没有出错. 比如下图: 虽然出现报错信息,但是,整个程序并没有出错.至于原因,图片上的文 ...
- FatJar in 创新实训 自然语言交流系统
Fat Jar Eclipse Plug-In是一个可以将Eclipse JavaProject的所有资源打包进一个可执行jar文件的小工具,可以方便的完成各种打包任务,我们经常会来打jar包,但是e ...
- webrtc 在MAC下和iOS下的编译
一:安装brew和git 1. mkdir /usr/local 2. curl -LsSf http://github.com/mxcl/homebrew/tarball/master | sudo ...
- Group Normalization
Group Normalization 2018年03月26日 18:40:43 阅读数:1351 FAIR 团队,吴育昕和恺明大大的新作Group Normalization. 主要的优势在于,BN ...
- http.sys的简单应用
//public void Run() //{ // //httpListener提供一个简单,可通过编程方式控制的Http协议侦听器.此类不能被继承. // if (!HttpListener.Is ...
- FastFel解析一个公式的步骤
FastFel 查看源码后,理解的运算步骤: 1) 创建一个 FelEngine,FelEngine fel = new FelEngineIml(); 2) 将表达式 exp 解析成为一个节点树 F ...
- JAVABEAN必须继承序列化借口的作用
这里有人家对序列化的测试 http://www.javaeye.com/topic/350137 Java的"对象序列化"能让你将一个实现了Serializable接口的对象转换成 ...
- 简单介绍Linux下安装Tomcat的步骤
Tomcat是一个免费的开源的Serlvet容器,它是Apache基金会的Jakarta项目中的一个核心项目,由Apache,Sun和其它一些公司及个人共同开发而成.由于有了Sun的参与和支持,最新的 ...
- thikphp5.0 ip地址库 解决卡顿问题 curl_init
使用淘宝新浪的地址库非常的使用,但是调用有时候会出现很慢.会导致卡在当前网页. 要想不影响当前速度,因此要使用 curl_init功能. 项目案例:会员登陆日志 user_log 字段:id,user ...
- redis的有序集合ZSET(stored set)
相关命令 1.ZADD ZADD key-name score member [score member……] 将带有给定分值的成员添加到有序集合里 2.ZREM ZREM key-name mem ...