文件操作
open()函数打开文件
open函数有八个参数
open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True)
file:文件绝对路径或相对路径下的文件名
mode:r(读) ,w(写) ,a(追加),rb,rw,ra
encoding="utf-8"
序号 | 方法及描述 |
---|---|
1 | 关闭文件。关闭后文件不能再进行读写操作。 |
2 | 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
3 | 返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 |
4 | 如果文件连接到一个终端设备返回 True,否则返回 False。 |
5 | Python 3 中的 File 对象不支持 next() 方法。 返回文件下一行。 |
6 | 从文件读取指定的字节数,如果未给定或为负则读取所有。 |
7 | 读取整行,包括 "\n" 字符。 |
8 | 读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。 |
9 | 移动文件读取指针到指定位置 |
10 | 返回文件当前位置。 |
11 | 从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 windows 系统下的换行代表2个字符大小。 |
12 | 将字符串写入文件,返回的是写入的字符长度。 |
13 | 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
os模块
功能:创建目录,删除目录,删除文件,执行操作系统命令等方法。
删除文件
os.remove(文件路径)
创建目录
os.mkdir(创建目录路径)
删除目录
os.rmdir(目录路径)
os.path
方法 | 说明 |
---|---|
os.path.abspath(path) | 返回绝对路径 |
os.path.basename(path) | 返回文件名 |
os.path.commonprefix(list) | 返回list(多个路径)中,所有path共有的最长的路径 |
os.path.dirname(path) | 返回文件路径 |
os.path.exists(path) | 如果路径 path 存在,返回 True;如果路径 path 不存在,返回 False。 |
os.path.lexists | 路径存在则返回True,路径损坏也返回True |
os.path.expanduser(path) | 把path中包含的"~"和"~user"转换成用户目录 |
os.path.expandvars(path) | 根据环境变量的值替换path中包含的"$name"和"${name}" |
os.path.getatime(path) | 返回最近访问时间(浮点型秒数) |
os.path.getmtime(path) | 返回最近文件修改时间 |
os.path.getctime(path) | 返回文件 path 创建时间 |
os.path.getsize(path) | 返回文件大小,如果文件不存在就返回错误 |
os.path.isabs(path) | 判断是否为绝对路径 |
os.path.isfile(path) | 判断路径是否为文件 |
os.path.isdir(path) | 判断路径是否为目录 |
os.path.islink(path) | 判断路径是否为链接 |
os.path.ismount(path) | 判断路径是否为挂载点 |
os.path.join(path1[, path2[, ...]]) | 把目录和文件名合成一个路径 |
os.path.normcase(path) | 转换path的大小写和斜杠 |
os.path.normpath(path) | 规范path字符串形式 |
os.path.realpath(path) | 返回path的真实路径 |
os.path.relpath(path[, start]) | 从start开始计算相对路径 |
os.path.samefile(path1, path2) | 判断目录或文件是否相同 |
os.path.sameopenfile(fp1, fp2) | 判断fp1和fp2是否指向同一文件 |
os.path.samestat(stat1, stat2) | 判断stat tuple stat1和stat2是否指向同一个文件 |
os.path.split(path) | 把路径分割成 dirname 和 basename,返回一个元组 |
os.path.splitdrive(path) | 一般用在 windows 下,返回驱动器名和路径组成的元组 |
os.path.splitext(path) | 分割路径,返回路径名和文件扩展名的元组 |
os.path.splitunc(path) | 把路径分割为加载点与文件 |
os.path.walk(path, visit, arg) | 遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数 |
os.path.supports_unicode_filenames | 设置是否支持unicode路径名 |
os.walk方法,主要用来遍历一个目录内各个子目录和子文件。
os.walk(top, topdown=True, οnerrοr=None, followlinks=False)
可以得到一个三元tupple(dirpath, dirnames, filenames),
第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。
dirpath 是一个string,代表目录的路径,
dirnames 是一个list,包含了dirpath下所有子目录的名字。
filenames 是一个list,包含了非目录文件的名字。
这些名字不包含路径信息,如果需要得到全路径,需要使用os.path.join(dirpath, name).
os.system
python 的os.system来执行系统命令
import os
path=os.path.dirname(__file__)
os.system("cls")
os.system("mkdir dir2")#创建文件夹
os.system("rmdir dir2")#删除文件夹
print os.system('ifconfig')
print os.system('ping www.pythontab.com')
.
shutil模块
import os
import shutil
path=os.path.dirname(__file__)
f1=open('1.txt','r',encoding='utf-8')
f2=open('2.txt','w',encoding='utf-8')
'''
文件的复制
'''
shutil.copyfileobj(f1,f2) #将f1中的文件拷贝到f2中
shutil.copyfile("枚举循环.py","copy2.txt")#如果copy.2没有则会新建一个copy2.txt并复制枚举循环.py的内容
shutil.copy("copy2.txt",'copy3.py')#拷贝文件和权限和内容
# shutil.copy2('sys模块.py','copy4.py')#拷贝文件和状态信息(包括权限)
# shutil.copystat('sys模块.py','copy2.py')#拷贝状态信息,modle bits(权限),atime(访问时间),mtime(修改时间),flags,即将所有的属性进行拷贝(要拷贝到的目的文件必须存在,即第二个文件必须存在)
# shutil.copymode('sys模块.py','copy1.py')#仅拷贝权限。内容、组、用户均不变(要拷贝到的目的文件必须存在,即第二个文件必须存在)
'''
批量删除和复制
'''
'''
shutil.copytree('旧目录名','新目录名') 递归的去拷贝文件(拷贝目录)
shutil.rmtree('目录名') 递归的去删除文件(删除目录)
shutil.move('文件名','目录名') 递归的去移动文件,目录必须存在
'''
文件压缩
'''
压缩文件
shutil.mak_archive(base_name,format,...)
创建压缩包并返回文件路径,例如:zip,tar
base_name:压缩后的文件路径或名字
format:压缩包种类:"zip","tar","bztar","gztar"
root_dir:要压缩文件夹的绝对路径
owner:用户,默认当前用户
group:组,默认当前组
logger:用于记录日志,通常是logging.Logger
'''
# shutil.make_archive压缩指定路径
print(45)
shutil.make_archive(r'F:/桌面/ox1','zip',r'F:\桌面\sd\1.txt')
print(87)
# 'shutil对压缩包的处理是调用ZipFile和TarFile两个模块进行的'
# import zipfile
# # '压缩'
# # z=zipfile.ZipFile('压缩实例_zip.zip','w')
# # z.write('sys模块.py')
# # print('可以干别的,不影响')
# # z.write('copy1.py')
# # z.close()
# # '解压'
# # z=zipfile.ZipFile('压缩实例_zip.zip','r')
# # z.extractall()
# # z.close()
glob模块
import glob
import os
path=os.path.dirname(__file__)
# for fname in glob.glob("*.py",recursive=True):
# print(fname)
#
# path=path+"/*.py"
# print(path)
# for fname in glob.glob(path,recursive=True):
# print(fname)
'''
glob.iglob() 函数
获取一个可遍历对象,使用它可以逐个获取匹配的文件路径名。
与glob.glob()的区别是:glob.glob()可同时获取所有的匹配路径,而glob.iglob()一次只能获取一个匹配路径。
'''
path=path+"/*.py"
print(path)
for fname in glob.iglob(path,recursive=True):
print(fname)