```python
import os
# 定义文件夹路径喊滚
folder_path = "/path/to/folder"
# 判断文件夹是否存在
if os.path.exists(folder_path):
# 获取目录下的所有文件和文件夹
files = os.listdir(folder_path)
# 遍历所有文件和文件夹
for file in files:
# 判断该路径是否为目录(即文件夹)
if os.path.isdir(os.path.join(folder_path, file)):
print("文件夹中包含子文件夹")
break
else:
print("文件夹中没有子桥正文件夹")
else:
print("文件夹不存在")
```
在上面的代码中,我们首先检查文件夹是否存在。然后,通过`os.listdir()`方法获取文件夹中的所有文件和文件夹,遍历每个文件和文件夹进行判断。使用`os.path.join()`方法将文件夹路径和文件名组合成完整的路径,并将其传递给`os.path.isdir()`方法,以确定是否为文件夹。如果存在子文件夹,则立即跳出循环并打印“文件夹中包含子文件夹”的消息。否则,将打印“文件夹中没有子文件夹”的消息。
例如:在C:\TDDOWNLOAD目录下有a.txt、b.txt两个文件,另有\sub1子文件夹,C:\TDDOWNLOAD\sub1下又有c.txt、d.txt两个文件。1.
os.walk
os.walk()返回一个三元素的tuple:当前路径、子文件夹名称、文件列表。>>>
import
os>>>
def
fun(
path
):...
for
root,
dirs,
files
in
os.walk(
path
):...
for
fn
in
files:...
root,
fn...
>>>
fun(
r'C:\TDDOWNLOAD'
)C:\TDDOWNLOAD
a.txtC:\TDDOWNLOAD
b.txtC:\TDDOWNLOAD\sub1
c.txtC:\TDDOWNLOAD\sub1
d.txt>>>
2.
glob.glob
glob.glob()只接受一个参数,这个参数既代有路径,又代有匹配模式,返回值为一个列表。注意,glob.glob()无法直接穿透子文件夹,需要自己处理:>>>
def
fun(
path
):...
for
fn
in
glob.glob(
path
+
os.sep
+
'*'
):
#
'*'代表匹配所有文件...
if
os.path.isdir(
fn
):
#
如果结果为文件夹...
fun(
fn
)
#
递归...
else:...
fn...
>>>
fun(
r'C:\TDDOWNLOAD'
)C:\TDDOWNLOAD\a.txtC:\TDDOWNLOAD\b.txtC:\TDDOWNLOAD\sub1\c.txtC:\TDDOWNLOAD\sub1\d.txt>>>
'*'为悄喊喊匹配渗握模式,代表匹配所启野有文件,只有这样才能将子文件夹查出来,以便递归深入,探查下一层的文件。
import osimport os.path
rootdir = “d:\data” # 指明灶伍铅被遍历的文件夹
for parent,dirnames,filenames in os.walk(rootdir):#三个参数:分别返回1.父目录 2.所有文橘让件夹名字(不含路径) 3.所有文件名字
for dirname in dirnames: #输出文件夹信息
print "parent is:" + parent
print "dirname is" + dirname
for filename in filenames:#输出文件信息
print "parent is": + parent
print "filename is:" + filename
print "the full name of the file is:" + os.path.join(parent,filename) #输出文件路径信息
#windows下为:d:\data\query_text\隐好EL_00154
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)