zhouxiaopan 发表于 2020-9-7 11:19:23

求大哥们帮忙解答下这个题目,红字的[1]加上去是干嘛的,这个程序的运行思路。这个...

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

zhouxiaopan 发表于 2020-9-7 11:23:49

望大神帮忙讲解一下这个程序整体的运行思路,跪谢,看得比较懵逼{:10_266:}

sunrise085 发表于 2020-9-7 11:24:12

本帖最后由 sunrise085 于 2020-9-7 11:28 编辑

os.path.splitext(each_file)得到的是两个元素的元组,元组的第一个元素是文件名,第二个元素是扩展名
所以右面加上就是取第二个元素,即文件扩展名

例如:each_file为 'file.txt',那么 os.path.splitext(each_file) 得到的就是元组 ('file','txt') 。 这样,os.path.splitext(each_file)就是 'txt'

bonst 发表于 2020-9-7 11:25:15

应该是表示分割后的第一项,[ ]表示index

zhouxiaopan 发表于 2020-9-7 11:26:50

sunrise085 发表于 2020-9-7 11:24
os.path.splitext(each_file)得到的是两个元素的元组,元组的第一个元素是文件名,第二个元素是扩展名
所 ...

谢谢!!原来如此!
页: [1]
查看完整版本: 求大哥们帮忙解答下这个题目,红字的[1]加上去是干嘛的,这个程序的运行思路。这个...