python怎么遍历文件夹内的删除文件_Python实现递归遍历文件夹并删除文件

思路:

遍历文件夹下面的文件夹

如果文件夹名称等于".svn",则修改文件夹的属性(因为".svn"的文件都是只读的,你不能直接删除)

删除此文件夹

如果文件夹名称不等于".svn",则递归上面的方法

Python的实现

代码import os

import shutil

import os.path

import stat

rootdir="F:\\work\\Test"

for parent,dirnames,filenames in os.walk(rootdir): #遍历文件夹下面的所有文件夹

for dirname in dirnames:

if dirname=='.svn':

strfilepath=parent+os.sep+dirname

if os.path.isdir(strfilepath):

os.system('attrib -r ' + parent + '\\*.* /s')#设置本文件夹可写

os.system('attrib -r ' + strfilepath + '\\*.* /s')#设置父文件夹可写

shutil.rmtree(parent+os.sep+dirname)#删除此文件夹

要点:

Walk在os模块下面,用来根据提供的文件夹生成一个generator。每次可以得到一个三元tupple,其中第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。

os.system('attrib -r ' + parent + '\\*.* /s') 设置文件夹可写

shutil.rmtree(parent+os.sep+dirname) 删除文件夹(即使文件夹里面有文件)

例二:

Python实现递归遍历指定文件目录(startdir),从而找到所有与指定的文件或目录(target)名相同的文件或目录的绝对路径。

scandir.py :#! /usr/bin/python

# filename : scandir.py

# author : Jesse

# update : 2011/08/15 10:16

import os

def scandir(startdir, target) :

os.chdir(startdir)

for obj in os.listdir(os.curdir) :

if obj == target :

print os.getcwd() + os.sep + obj

if os.path.isdir(obj) :

scandir(obj, target)

os.chdir(os.pardir) #!!!

startdir = raw_input('Please input startdir: ')

target = raw_input('Please input target: ')

scandir(startdir, target)

关于该程序的一点说明:

1. 函数scandir的形参target可以是目录名也可以是文件名。

2. 函数chdir的作用是切换到指定目录,该参数必须是有效的且有访问权限的相对路径或绝对路径。

3. 函数的第五行,使用getcwd函数也是为了取得当前绝对路径。

4. 加号作为字符串的连接符。os.sep根据你的操作系统给出目录分隔符,在GNU/Linux和UNIX上它的返回值是'/',在windows上它的返回值是'\\',在Mac OS上是‘:',使用os.sep而不直接使用字符,会提高程序的可移植性。

5. 递归调用后,一定不能忘了os.chdir(os.pardir),返回上层目录(即父目录)。

重要:

1. 理解for中的两个并列的if语句,并列是为了解决目标是文件夹时,该目标文件夹中包含符合要求的文件夹。

2. 如果指定目录中存在访问受限的文件或文件夹,该程序会失败,返回无权访问信息。

例三:

Python递归遍历文件夹,寻找包含某个字符串的文本文件

linux下,如果不使用eclipse的话,想查找某个字符串在哪些文件中出现过就很麻烦,自己写了这个脚本在编码时使用,挺方便的。如果某个文本文件中包含的话,则只记录出现第一次的行数输出

使用方法:

python xxx.py 路径 字符串

python search_content.py /home/www/ abcdefg

search_content.py#!/use/bin/env python

#-*- coding:utf-8 -*-

import sys,os

filterType = ['gif','png','bmp','jpg','jpeg','rar','zip',

'ico','apk','ipa','doc','docx','xls','jar',

'xlsx','ppt','pptx','pdf','gz','pyc','class']

num = 0

def search(path=None,cont=None):

if not path or not cont:

print('path or searchString is empty')

return

global num

_loopFolder(path,cont)

print("%s file find" % num)

def _loopFolder(path,cont):

arr = path.split('/')

if not arr[-1].startswith('.'): #不检查隐藏文件夹

if os.path.isdir(path):

folderList = os.listdir(path)

for x in folderList:

_loopFolder(path+"/"+x,cont)

elif os.path.isfile(path):

_verifyContent(path,cont)

def _verifyContent(path,cont):

if path.split('.')[-1].lower() in filterType:

return

global num

fh = open(path,'r')

fhContent = fh.readlines()

fh.close()

for index,x in enumerate(fhContent):

if cont in x:

num += 1

print("%s %s" % (path,index+1))

break

return

if __name__ == "__main__":

if len(sys.argv) < 3:

print("invalid parameters")

else:

search(sys.argv[1],sys.argv[2])

更多Python实现递归遍历文件夹并删除文件相关文章请关注PHP中文网!

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用os模块来实现遍历文件夹内所有文件内容的功能,以下是Python代码示例: ```python import os def traverse_files(rootdir): for subdir, dirs, files in os.walk(rootdir): for file in files: filepath = os.path.join(subdir, file) with open(filepath, 'r') as f: content = f.read() # 在此处对文件内容进行处理 print(content) ``` 在这个示例,`os.walk()`函数用于遍历指定路径下的所有文件夹、子文件夹文件。`os.path.join()`函数用于拼接文件路径。`with open() as f:`语句用于打开文件,并在文件处理完成后自动关闭文件。在这个示例,可以在`with`语句添加对文件内容的处理代码。 ### 回答2: 在Python,可以使用os模块和递归函数来遍历文件夹内的所有文件内容。下面是一个示例代码: ```python import os def traverse_folder(folder_path): for root, dirs, files in os.walk(folder_path): # 递归遍历文件夹内的所有文件和子文件夹 for file_name in files: file_path = os.path.join(root, file_name) # 获取文件的完整路径 with open(file_path, 'r') as file: file_contents = file.read() # 读取文件内容 print(file_contents) # 处理文件内容,这里只是简单地打印出来 folder_path = '/path/to/folder' # 替换为你想要遍历文件夹路径 traverse_folder(folder_path) ``` 上述代码,`traverse_folder`函数使用`os.walk`函数遍历文件夹内的所有文件和子文件夹。在遍历过程,通过`os.path.join`函数获取每个文件的完整路径,并使用`open`函数打开文件。接着,使用`read`方法读取文件内容,并进行相应的处理操作。这里只是简单地打印出文件内容。 需要注意的是,`folder_path`变量需要替换为你想要遍历文件夹路径。使用该代码可以遍历指定文件夹内所有文件的内容。 ### 回答3: Python可以使用os模块来遍历文件夹内的所有文件内容。以下是一个示例代码,用于遍历指定文件夹内的所有文件并输出文件内容: ```python import os def traverse_files(folder_path): for root, dirs, files in os.walk(folder_path): for file in files: file_path = os.path.join(root, file) with open(file_path, 'r') as f: content = f.read() print(content) # 指定要遍历文件夹路径 folder_path = "目标文件夹路径" traverse_files(folder_path) ``` 在以上代码,首先导入了os模块。然后定义了一个名为`traverse_files`的函数,该函数接受一个文件夹路径作为参数。在函数内部,使用`os.walk()`函数遍历文件夹及其子文件夹,并返回当前文件夹路径、子文件夹列表和文件列表。然后,使用两个嵌套的for循环遍历文件列表,并在每次循环文件路径与文件名合并为完整文件路径。最后,使用`open()`函数打开文件,并使用`read()`方法读取文件内容,将内容存储在变量content。然后,通过打印content来输出文件内容。 使用以上代码,您可以在指定的文件夹遍历所有文件,并将它们的内容输出到控制台。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值