十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
python中遍历文件夹并统计所有文件大小,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
成都创新互联公司是一家以网络技术公司,为中小企业提供网站维护、网站建设、网站设计、网站备案、服务器租用、域名注册、软件开发、小程序开发等企业互联网相关业务,是一家有着丰富的互联网运营推广经验的科技公司,有着多年的网站建站经验,致力于帮助中小企业在互联网让打出自已的品牌和口碑,让企业在互联网上打开一个面向全国乃至全球的业务窗口:建站联系热线:13518219792
递归解题的思路没什么出奇的,代码特别简洁易懂。遍历一个目录,累计所有文件的大小,对于子目录则调用自身递归统计子目录。
需要注意的有两点:
一、路径书写强烈建议用“/”,这种写法在windows系统和linux系统通用。
二、文件与路径拼接方法,经time测试用f字符串拼接方式比用os.path.join()方式拼接效率略高一些,而且书写也简洁一些。
import osdef getdir1(path):name_list = os.listdir(path)size = 0for i in name_list:j = f'{path}/{i}' # 文件和路径拼接用字符串+更直接更高效# j = os.path.join(path,i)if os.path.isdir(j):size += getdir1(j)else:size += os.path.getsize(j)return sizeprint(getdir1('D:/学习资料'))out:304372584432
循环解题的思路要注意以下两点:
一、对列表的pop和append用法,这样实际是将列表当成了堆栈使用,后进先出。
二、注意 while name_dir的写法,这个是判断name_dir列表是否为空,为空则结束循环,不为空则循环。
def getdir2(path):size = 0name_dir = [path]while name_dir:name_list = os.listdir(ret := name_dir.pop())for i in name_list:j = f'{ret}/{i}'if os.path.isfile(j):size += os.path.getsize(j)else:name_dir.append(j)return sizeprint(getdir2('D:/学习资料'))out:304372584432
看完上述内容,你们掌握python中遍历文件夹并统计所有文件大小的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!