这是我到目前为止所得到的:
project_dir = '/my/project/dir'
project_depth = len(project_dir.split(os.path.sep))
xml_files = []
for dirpath, dirnames, filenames in os.walk(project_dir):
for filename in fnmatch.filter(filenames, '*.xml'):
dirs = dirpath.split(os.path.sep)[project_depth:]
print(dirs)
xml_files.append(os.path.join(dirpath,filename))
基本上我想要做的是吐出我的项目目录结构,将所有XML文件作为HTML树(使用< ul>).我可以通过这种方式获取所有文件,但我似乎无法弄清楚如何将它们组织到树中.
通过这个os.walk的工作方式,我不知道我什么时候进入更深层,或者我还在遍历同一个目录.
for dirpath, dirnames, filenames in os.walk(project_dir):
xml_files = fnmatch.filter(filenames, '*.xml')
if len(xml_files) > 0:
out.write('
{0}- '.format(dirpath))
for f in xml_files:
out.write('
{0}'.format(f))out.write('
')out.write('')
这给了我一个目录列表和它们下面的所有文件,但我仍然无法弄清楚如何拆分目录路径以便它也嵌套.
解决方法:
如果你关心层次结构,os.walk可能不是最好的解决方案.一个更简单的解决方案可能就是使用os.listdir和os.path.isdir以递归方式遍历树.
import os
def traverse(dir):
print '
- '
for item in os.listdir(dir):
print '
%s' % itemfullpath = os.path.join(dir, item)
if os.path.isdir(fullpath):
traverse(fullpath)
print '
'projectdir = '.'
traverse(projectdir)
标签:python,operating-system,file,directory,filesystems
来源: https://codeday.me/bug/20190726/1541748.html