好难懂的代码
本帖最后由 萌萌的小霈 于 2021-2-7 09:44 编辑0. 编写一个程序,统计当前目录下每个文件类型的文件数。
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)
type_dict.setdefault(ext, 0)
type_dict += 1
for each_type in type_dict.keys():
print('该文件夹下共有类型为【%s】的文件 %d 个' % (each_type, type_dict))
(加空行)第11行对文件名字进行切片后返回一个元组(文件名, .类型名)那后面那个有什么用?是文件模块的新用法吗?
我在IDLE里试过去掉结果是把我当前目录下的每一个文件都打印出来,为什么一定要加个上去?
你打印一下它不加的返回值就知道了 qiuyouzhi 发表于 2021-2-7 09:35
你打印一下它不加的返回值就知道了
打印了,还是不知道为什么加了之后就可以只输出类型名和个数 萌萌的小霈 发表于 2021-2-7 09:37
打印了,还是不知道为什么加了之后就可以只输出类型名和个数
是索引啊
os.path.splitext会返回一个元组
第一个元素是文件路径,第二个是文件的后缀名
建议重学下列表
页:
[1]