第030讲:文件系统:介绍一个高大上的东西

请写下这一节课你学习到的内容:格式不限,回忆并复述是加强记忆的好方式!

介绍跟Python的文件相关且十分有用的模块。模块是什么?
模块是一个包含你定义的函数和变量的文件,后缀是.py,模块可以做到被别的程序所引入,以使用该模块中的函数等功能。
OS模块(Operating System操作系统)
对于文件系统的访问来说,Python一般是提供OS模块来实现就可以了,我们所知道常用的操作系统有:Windows,Mac,OS,Linux,UNIX等,这些操作系统底层由于文件系统的访问工作原理不同,因此你可能就要针对不同的系统来考虑使用哪些文件系统模块…这样的做法是非常不友好且麻烦的,因为这样就意味着当你的程序运行环境一改变,你就要相应的去修改大量的代码来应付。但是我们的Python是跨平台的,所以Python就有了这个OS模块。
有了OS模块,我们不需要关心什么操作系统下使用什么模块,OS模块会帮你选择正确的模块并调用。

os.path模块中关于路径常用的函数使用方法

函数名使用方法
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下为’\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)判断指定路径是否存在且是一个符号链接(在windows上即为快捷方式)
ismount(path)判断指定路径是否存在且是一个挂载点
samefile(path1, paht2)判断path1和path2两个路径是否指向同一个文件

0. 编写一个程序,统计当前目录下每个文件类型的文件数,程序实现如图:

在这里插入图片描述

def localFileType():
    import os
    type_dict = dict()
    files=os.listdir(os.getcwd())
    for each in files:
        if os.path.isdir(each):
            type_dict.setdefault('文件夹', 0)#如果已经存在文件夹这个关键字,不会新建
            type_dict['文件夹']+=1
        else:
            ext = os.path.splitext(each)[1]
            type_dict.setdefault(ext, 0)
            type_dict[ext] += 1
    for each_type in type_dict.keys():
        print('该文件夹下共有类型为【%s】的文件 %d 个' % (each_type, type_dict[each_type]))
localFileType()

1.编写一个程序,计算当前文件夹下所有文件的大小,程序实现如图:

在这里插入图片描述

import os
def fileSize(path):
    os.chdir(path)
    for eachfile in os.listdir(os.getcwd()):
        print('%s[%d字节]'%(eachfile,os.path.getsize(eachfile)))

path=input("输入路径:")
fileSize(path)

2. 编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索,程序实现如图:

在这里插入图片描述

import os
def searchPath(path,fileName):
    os.chdir(path)

    for each in os.listdir(os.curdir):
        if os.path.isdir(path+os.sep+each):
            searchPath(path+os.sep+each,fileName)
        if each==fileName:
            print(path+os.sep+fileName)

    
path=input("请输入路径:")
searchPath(path,'txt.txt')
        
        

3. 编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径,程序实现如图:

import os
listVideo=[] #全局变量
def searchVideo(path):
    list1=['.mp4' ,'.rmvb', '.avi']
    for each in os.listdir(path):
        if os.path.splitext(each)[1] in list1:
            listVideo.append(each+'\n')
        elif os.path.isdir(each):
            searchVideo(path+os.sep+each)
def Save(path,listVideo):
    f = open( path+ os.sep + 'vedioList.txt', 'w')
    f.writelines(listVideo)

path=input("输入路径:")
searchVideo(path)
Save(path,listVideo)

4. 编写一个程序,用户输入关键字,查找当前文件夹内(如果当前文件夹内包含文件夹,则进入文件夹继续搜索)所有含有该关键字的文本文件(.txt后缀),要求显示该文件所在的位置以及关键字在文件中的具体位置(第几行第几个字符),程序实现如图在这里插入图片描述

import os
def searchKeyWord(path,keyword):
    for each in os.listdir(path):
        abPath=path+os.sep+each
        if os.path.splitext(each)[1]=='.txt':
            findPos(abPath,keyword)
        elif os.path.isdir(abPath):
            searchKeyWord(abPath,keyword)
            
def findPos(abPath,key):
    print(abPath)
    f=open(abPath)
    count=1
    for line in f:
        list1=[]
        begin = line.find(key)
        while begin != -1:
            list1.append(begin+1)
            begin = line.find(key, begin+1) # 从下一个位置继续查找
        if len(list1)>0:
            print('第%d行,第%s个位置'% (count,list1),end='\n')#正常应该从1开始
        count+=1

path,keyword=input("输入路径和关键字(用逗号隔开):").split(',')
searchKeyWord(path,keyword)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值