|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
import os
all_files = os.listdir(os.curdir) # 使用os.curdir表示当前目录更标准
type_dict = dict()
for each_file in all_files:
if os.path.isdir(each_file):
type_dict.setdefault('文件夹', 0)
type_dict['文件夹'] += 1
else:
ext = os.path.splitext(each_file)[1]
type_dict.setdefault(ext, 0)
type_dict[ext] += 1
for each_type in type_dict.keys():
print('该文件夹下共有类型为【%s】的文件 %d 个' % (each_type, type_dict[each_type]))
该代码第二行 os.listdir(os.curdir)的返回值不是一个序列吗?就是只有文件名称的序列。比如[文本.txt,小甲鱼.avi]
该代码第五行 if os.path.isdir(each_file): 这里怎么能判读一个序列是一个文件呢?序列不等于文件吧?
本帖最后由 Twilight6 于 2020-6-28 22:40 编辑
该代码第二行 os.listdir(os.curdir)的返回值不是一个序列吗?就是只有文件名称的序列。比如[文本.txt,小甲鱼.avi]
是的,在 Python 中 列表、元组、字符串都属于序列,所以这里准确的来说返回的是列表,而这个列表里面包含了这个文件夹下的所有文件名或文件夹名
该代码第五行 if os.path.isdir(each_file): 这里怎么能判读一个序列是一个文件呢?序列不等于文件吧?
因为这里用 for 循环把列表里的文件都一个个拿出来了,而不是把整个列表放到里面去判断,注意这里的参数是 each_file 而不是 all_files
all_files 这个列表才代表你是整个文件列表, 是不等于文件的,一个是列表,一个是文件名的字符串,怎么会相等呢?是吧
|
|