python怎么删除文件夹以及里面的所有文件?

Python014

python怎么删除文件夹以及里面的所有文件?,第1张

os包的rmdir()函数可以用来删除一个文件夹,但是文件夹必须是空的。一种可行的方法是读取文件夹的文件列表,逐个删除文件夹中的所有文件,然而文件夹中可能还有文件夹,因此这是一个递归的操作。\x0d\x0ashutil包rmtree()函数就实现了以上功能。shutil是一个高级文件操作的包,实现了文件及文件集合复制与删除的功能。rmtree()函数接收非空文件夹的路径这唯一一个参数。示例代码如下:\x0d\x0aimport shutil\x0d\x0apath = 'g:\zhidao'\x0d\x0ashutil.rmtree(path)

首先登场的选手是python的列表,列表属于可变类型,所以它将有完整的增删改查方法,让我们一起来看看具体是什么。

增,顾名思意就是可以对列表进行新增元素的操作,python的列表提供了三种新增元素的操作,分别是:append() ,insert(), extend()

首先是append(),它可以将一个元素追加到列表的末尾。

举个栗子:

上述代码中,我们使用的是li.append('新增内容')的方式来为列表添加元素

li.append()使列表li调用自身的方法append(),这样就可以在列表的末尾添加一个新的元素。

接下来是insert(),append()是排队,那insert()就是插队的意思啦,它可以将一个元素插入到列表的自定位置:

li.insert(索引,元素)

这样就将字符串helloworld插入到了列表的第四个位置里。

上面两个方法是对单个元素进行增加,如果我们需要增加多个元素怎么办?

那就可以使用我们的extend()来进行添加,extend()可以将序列中的每个元素添加到末尾:

上面的代码先定义了两个列表l1和l2,然后使用l1.extend(l2),将l2的每个元素添加到了l1的末尾。

增加讲完了,接下来进行删除操作,删除也有对应的四个方法:del(),pop(),remove(),clear()

del()是单独的方法,不需要通过列表本身来进行调用,可以直接使用:

上述代码删除了li[0],但是请注意,如果不进行索引的话,默认会将这个变量删除,请谨慎使用:

这就是删除了整个变量,再打印这个变量时就会提示变量未定义

pop()方法不带参数的话删除默认删除最后一个元素,带参数的话则删除指定的下标值:

pop()还有个神奇的地方,它可以让你需要删除的参数取出来继续使用,使用完了再进行删除:

上述代码使用pop()删除了第一个元素,然后使用第一个元素进行了一个简单的判断,说明pop()可以为我们返回删除的元素,让我们先使用,使用完再删除

remove()用来删除一个指定元素,无返回值,无法使用下标删除:

上述代码使用remove()删除了一个元素l

clear()用于清空列表,与del不同的是,它会为我们保留空列表,而不会把变量都删除:

上述代码清除了列表后,保留了空列表

改的方法就比较简单,直接索引出下标重新赋值即可:

这里就对li[0]进行了重新赋值

有通过index查询指定元素返回对应下标,也可以使用count来计算该元素出现过的次数:

除了增删改查,列表中还有其他的方法复制copy()、倒叙排列reverse()、从小到大排列sort()

使用li.copy(),再用一个变量接收复制的列表,就可以实现复制出一个新的列表来

sort()方法可以将数字类型的进行从小到大的排列,一般也用于同类型的排列

元组作为不可变类型,只能查和删,如果需要其他操作需要转换成列表

只能删除整个元组,无法使用下标值,删除后再使用会提示没有定义变量

元组只有查和删的方法,如果需要修改应先转成列表修改再转回元组,但是不建议这么做,因为修改过的元组就已经不是原来的那个元组了,而且设置元组也是为了这组数据不希望受到修改

以上就是关于列表&元组的方法了,有兴趣的小伙伴可以自己尝试一下。

如果有哪些错误或者不好的地方,还请各位大佬指出来,我会虚心接受并修改错误,谢谢!

python的列表list可以用for循环进行遍历,实际开发中发现一个问题,就是遍历的时候删除会出错,例如

l = [1,2,3,4]

for i in l:

if i != 4:

l.remove(i)

print l

这几句话本来意图是想清空列表l,只留元素4,但是实际跑起来并不是那个结果。再看下面,利用index来遍历删除列表l

l = [1, 2, 3, 4]

for i in range(len(l)):

if l[i] == 4:

del l[i]

print l

这样没问题,可以遍历删除,但是列表l如果变为 l = [1,2,3,4,5]

如果还是按照上面的方法,设想一下,range开始的范围是0-4,中间遍历的时候删除了一个元素4,这个时候列表变成了= [1,2,3,5],这时候就会报错了,提示下标超出了数组的表示,原因就是上面说的遍历的时候删除了元素

所以python的list在遍历的时候删除元素一定要小心

可以使用filter过滤返回新的list

l = [1,2,3,4]

l = filter(lambda x:x !=4,l)

print l

这样可以安全删除l中值为4的元素了,filter要求两个参数,第一个是规则函数,第二个参数要求输入序列,而lambda这个函数的作用就是产生一个函数,是一种紧凑小函数的写法,一般简单的函数可以这么些

或者可以这样

l = [1,2,3,4]

l = [ i for i in l if i !=4]//同样产生一个新序列,复值给l

print l

或者干脆建立新的list存放要删除的元素

l = [1,2,3,4]

dellist = []

for i in l:

if i == 4:

dellist.append(i)

for i in dellist:

l.remove(i)

这样也能安全删除元素

所以要遍历的时候删除元素一定要小心,特别是有些操作并不报错,但却没有达到预期的效果

上面说到产生新序列,赋值等等,用python的id()这个内置函数来看对象的id,可以理解为内存中的地址,所以有个简要说明

如果

l = [1,2,3,4]

ll = l

l.remove(1)

print l//肯定是[2,3,4]

print ll//这里会是什么?

如果用id函数查看的话就发现

print id(l),id(ll)

打印出相同的号码,说明他们其实是一个值,也就是说上面的print ll将和l打印的一样,所以python有这种性质,用的时候注意一下就行了