Python 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).

通过for循环自动完成递归枚举

例如:

F:\aaa 目录是这样的文件目录结构

F:\aaa

|--------1.txt

|--------2.txt

|--------3.txt

|--------4

         |-------5.txt

         |-------6.txt

         |-------7.txt


#!/usr/bin/env python
# 2.py
# use UTF-8
# Python 3.3.0

# os.walk()的使用
import os

# 枚举dirPath目录下的所有文件

def main():
#begin
	fileDir = "F:" + os.sep + "aaa"		# 查找F:\aaa 目录下	
	for root, dirs, files in os.walk(fileDir):
	#begin
		print(root)
		print(dirs)
		print(files)
	#end
	os.system("pause")
#end

if __name__ == '__main__':
#begin
	main()
#end


# 输出
# F:\aaa
# ['4']
# ['1.txt', '2.txt', '3.txt']
# F:\aaa\4
# []
# ['5.txt', '6.txt', '7.txt']

你也可以这样

#!/usr/bin/env python
# 3.py
# use UTF-8
# Python 3.3.0

# os.walk()的使用
import os

# 枚举dirPath目录下的所有文件

def main():
#begin
	fileDir = "F:" + os.sep + "aaa"		# 查找F:\aaa 目录下	
	for a in os.walk(fileDir):
	#begin
		print(a[0])
		print(a[1])
		print(a[2])
	#end
	os.system("pause")
#end

if __name__ == '__main__':
#begin
	main()
#end


# 输出
# F:\aaa
# ['4']
# ['1.txt', '2.txt', '3.txt']
# F:\aaa\4
# []
# ['5.txt', '6.txt', '7.txt']

通过for循环即可完成目录的递归.


你还可以这样

#!/usr/bin/env python
# 2.py
# use UTF-8
# Python 3.3.0

# os.walk()的使用
import os

# 枚举dirPath目录下的所有文件

def main():
#begin
	fileDir = "F:" + os.sep + "aaa"		# 查找F:\aaa 目录下	
	for root, dirs, files in os.walk(fileDir):
	#begin
		for dir in dirs:
		#begin
			print(os.path.join(root, dir))
		#end
		for file in files:
		#begin
			print(os.path.join(root, file))
		#end
	#end
	os.system("pause")
#end

if __name__ == '__main__':
#begin
	main()
#end


# 输出
# F:\aaa\4
# F:\aaa\1.txt
# F:\aaa\2.txt
# F:\aaa\3.txt
# F:\aaa\4\5.txt
# F:\aaa\4\6.txt
# F:\aaa\4\7.txt








<think>好的,我现在要详细解释一下Python中的os.walk()函数。首先,我需要回忆这个函数的作用,它应该是用来遍历目录树的,对吧?用户可能想知道它的基本用法、参数以及返回的内容。 我记得os.walk()会生成目录中的文件名,通过遍历顶向下或底向上的方式。那它返回的是一个三元组,包含根目录、子目录列表和文件列表。可能需要具体说明每个部分的含义。 接下来,我应该考虑参数。topdown参数控制遍历顺序,默认为True,即先处理当前目录再处理子目录。如果设为False,就是自底向上。还有onerror和followlinks参数,但用户可能更关注基本用法,这些高级参数可以简要提到。 然后,使用场景的例子。比如统计文件夹大小、批量重命名文件、查找特定文件等。这些例子能帮助用户理解实际应用。 需要注意的问题,比如符号链接的处理,默认followlinks是False,如果设为True可能会有循环风险。还有处理权限问题时的异常处理,可能需要try-except块。 可能用户会遇到的常见错误,比如路径不存在,或者没有访问权限。这时候需要提醒他们检查路径是否正确,处理异常。 接下来,我需要组织这些信息,结构清晰。先介绍函数的作用,然后参数详解,返回值解释,接着给出示例代码,说明每个步骤,最后注意事项和常见应用场景。 在示例代码部分,最好展示一个简单的遍历,并打印目录结构。比如从某个路径开始,遍历所有子目录和文件,输出它们的路径。这样用户可以直接运行代码看效果。 还要提到在Python的不同版本中是否有变化,但os.walk()在Python2和3中的表现应该是一致的,可能不需要特别说明版本差异。 最后,确保使用中文,避免专业术语过于晦涩,用通俗的语言解释。同时检查LaTeX格式是否正确,不过在这个问题中可能用不到数学公式,但如果有变量名之类的,可以用行内代码标记。 总结一下,回答的结构应该是: 1. 函数作用 2. 参数说明 3. 返回值 4. 示例代码 5. 注意事项 6. 应用场景 这样用户能一步步理解os.walk()的使用方法,并且知道如何应用到实际项目中。</think>Python中的`os.walk()`是一个用于遍历目录树的实用函数,它可以帮助你递归访问指定路径下的所有子目录和文件。以下是逐步说明: --- ### **1. 函数作用** - **遍历目录**:从给定的根目录开始,逐层访问所有子目录。 - **获取信息**:返回每个目录下的子目录列表和文件列表。 - **灵活控制**:支持自上而下(默认)或自底向上的遍历顺序。 --- ### **2. 参数说明** ```python os.walk(top, topdown=True, onerror=None, followlinks=False) ``` - `top`:要遍历的根目录路径(字符串类型)。 - `topdown`(可选): - 若为`True`(默认),先处理当前目录,再处理子目录(自上而下)。 - 若为`False`,先处理子目录,最后处理当前目录(自底向上)。 - `onerror`(可选):处理遍历时的异常的回调函数。 - `followlinks`(可选):若为`True`,会跟踪符号链接目录(默认`False`)。 --- ### **3. 返回值** 生成一个包含三元组的生成器 `(root, dirs, files)`: - `root`:当前正在访问的目录路径(字符串)。 - `dirs`:当前目录下的子目录名列表(不包含完整路径)。 - `files`:当前目录下的文件名列表(不包含完整路径)。 --- ### **4. 示例代码** ```python import os # 遍历当前目录下的所有文件和子目录 for root, dirs, files in os.walk("."): print(f"当前目录:{root}") print(f"子目录:{dirs}") print(f"文件:{files}") print("---") ``` --- ### **5. 注意事项** - **符号链接**:默认不跟踪符号链接(避免循环遍历风险),需显式设置`followlinks=True`。 - **修改`dirs`列表**:遍历时若直接修改`dirs`列表,可控制后续遍历的子目录(例如跳过某些文件夹): ```python for root, dirs, files in os.walk("."): if "skip_this_dir" in dirs: dirs.remove("skip_this_dir") # 跳过名为 "skip_this_dir" 的目录 ``` - **性能**:遍历大型目录时可能较慢,建议避免在循环内执行复杂操作。 - **异常处理**:若目录无访问权限,会触发`PermissionError`,需通过`onerror`参数处理。 --- ### **6. 常见应用场景** - **统计文件数量**: ```python file_count = 0 for root, dirs, files in os.walk("."): file_count += len(files) print(f"总文件数:{file_count}") ``` - **查找特定文件**: ```python target_files = [] for root, dirs, files in os.walk("."): for file in files: if file.endswith(".txt"): target_files.append(os.path.join(root, file)) ``` - **批量重命名文件**:遍历文件并修改名称(需谨慎操作)。 --- 通过`os.walk()`,你可以高效地操作复杂的目录结构,适用于文件管理、数据分析等场景。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值