shutil模块
shutil模块中包含一些函数,提供复制、移动、改名和删除文件的功能。要使用shutil的函数,首先需要import shutil。
调用shutil.copy(source,destination),将路径source处的文件复制到路径destination处的文件夹(source和destination都是字符串)。如果destination是一个文件名,它将作为被复制文件的新名字。该函数返回一个字符串,表示被复制文件的路径。
shutil.copy()将复制一个文件,shutil.copytree()将复制整个文件夹,以及它包含的文件夹和文件。shutil.copytree()函数返回一个字符串,是新复制的文件夹的路径。
>>> import shutil,os >>> os.chdir('/tmp/') >>> shutil.copy('./1.txt','/tmp/newdir/') '/tmp/newdir/1.txt' >>> shutil.copy('./1.txt','/tmp/newdir/2.txt') '/tmp/newdir/2.txt' >>> import os,shutil >>> shutil.copytree('/tmp/newdir','/usr/local/newdir_backup') '/usr/local/newdir_backup'
调用shutil.move(source,destination),将路径source处的文件夹移动到路径destination,并返回新位置的绝对路径的字符串。
如果找不到destination的文件夹,python会假定destination指的是一个文件,而非文件夹。
构成目的地的文件夹必须已经存在,否则python会抛出异常。
>>> import shutil >>> shutil.move('/usr/local/newdir_backup','/tmp/newdir/') '/tmp/newdir/newdir_backup'
利用os模块中的函数,可以删除一个文件或一个空文件夹。但利用shutil模块,可以删除一个文件夹及其所有的内容。
☉用os.unlink(path)将删除path处的文件。
☉调用os.rmdir(path)将删除path处的文件夹。该文件夹必须为空,其中没有任何文件和文件夹。
☉调用shutil.rmtree(path)将删除path处的文件夹,它包含的所有文件和文件夹都会被删除。
在程序中使用这些函数时,可以在第一次运行程序时,注释掉这些调用,并且加上print()调用,显示会被删除的文件。
import os for filename in os.listdir(): if filename.endswitch('.rxt'): #os.uplink(filename) print(filename)
使用内建的shutil.rmtree()函数不可恢复地删除文件和文件夹,所以用起来可能有危险。
删除文件和文件夹的更好方法,是使用第三方的send2trash模块。
它将文件夹和文件发送到计算机的垃圾箱或回收站,而不是永久删除它们。
一般来说,总是应该使用send2trash.send2trash()函数来删除文件和文件夹。
这种方式,不像永久删除文件,不会释放磁盘空间。
send2trash()函数只能将文件送到垃圾箱,不能从中恢复文件。
[root@juispan newdir]# pip install send2trash Collecting send2trash Downloading Send2Trash-1.3.0.tar.gz Building wheels for collected packages: send2trash Running setup.py bdist_wheel for send2trash ... done Stored in directory: /root/.cache/pip/wheels/15/76/b3/a81bb5d0bfc6157d1e5df52d34cbea6ffe8a0fc6fea83bddb0 Successfully built send2trash Installing collected packages: send2trash Successfully installed send2trash-1.3.0
>>> import send2trash >>> newFile=open('/tmp/new.txt','a') >>> newFile.write('Hello World!') >>> newFile.close() >>> send2trash.send2trash('/tmp/new.txt')
遍历目录树
os.walk()函数被传入一个字符串值,即一个文件夹的路径。
可以在一个for循环语句中使用os.walk()函数,遍历目录树,就像使用range()函数遍历一个范围的数字一样。
▎不像range(),os.walk()在循环的每次迭代中,返回3个值:
1、当前文件夹名称的字符串。
2、当前文件夹中子文件夹的字符串的列表。
3、当前文件夹中文件的字符串的列表。
所谓的当前文件夹,是指for循环当前迭代的文件夹。程序的当前工作目录,不会因为os.walk()而改变。
>>> import os >>> for dir,subdirs,files in os.walk('/tmp/'): ... print('dir: '+dir) ... for subdir in subdirs: ... print('subdir: '+subdir) ... for file in files: ... print('file: '+file) ... print('') ... dir: /tmp/ subdir: .font-unix subdir: .X11-unix subdir: .ICE-unix subdir: .Test-unix ......
zipfile模块
将多个文件打包成一个文件,这个文件叫做“归档文件”。
要创建一个ZipFile对象,就调用zipfile.ZipFile()函数,向它传入一个字符串,表示.zip文件的文件名。
zipfile是python模块的名称,ZipFile()是函数的名称。
ZipFile对象有一个namelist()方法,返回ZIP文件中包含的所有文件和文件夹的字符串的列表。这些字符串可以传递给ZipFile对象的getinfo()方法,返回一个关于特定文件的ZipInfo对象。ZipInfo对象有自己的属性,诸如表示字节数的file_size和compress_size,它们分别表示原来文件大小和压缩后文件大小。ZipFile对象表示整个归档文件,而ZipInfo对象则保存该归档文件中每个文件的有用信息。
>>> import zipfile,os >>> zipFile=zipfile.ZipFile('/tmp/new.zip') >>> zipFile.namelist() ['tmp/newdir/1.txt'] >>> zipInfo=zipFile.getinfo('tmp/newdir/1.txt') >>> zipInfo.file_size 1100 >>> zipInfo.compress_size 482 >>> zipFile.close()
ZipFile对象的extractall()方法从ZIP文件中解压缩所有文件和文件夹,放到当前工作目录中。
如果传递给extractall()方法的文件夹不存在,它会被创建。
extract()方法可以从ZIP文件中解压缩单个文件。
传递给extract()的字符串,必须匹配namelist()返回的字符串列表中的一个。
可以向extract()传递第二个参数,将文件解压缩到指定的文件夹,而不是当前工作目录。
如果第二个参数指定的文件夹不存在,python就会创建它。
extract()的返回值是被压缩后文件的绝对路径。
>>> import os,zipfile >>> extractZip=zipfile.ZipFile('/tmp/new.zip') >>> extractZip.extractall() >>> extractZip.close()
如果向ZipFile对象的write()方法传入一个路径,python就会压缩该路径所指的文件,将它加入ZIP文件中。
write()方法的第一个参数是一个字符串,代表要添加的文件名。第二个参数是“压缩类型”参数,可以总是设置为“zipfile.ZIP_DEFLATED”。
就像写入文件一样,写模式将擦除ZIP文件中所有原有的内容。如果需要添加,使用“a”作为第二个参数。
>>> import zipfile,os >>> newZip=zipfile.ZipFile('/tmp/new.zip','w') >>> newZip.write('/tmp/newdir/1.txt',compress_type=zipfile.ZIP_DEFLATED) >>> newZip.close()