使用 Python 一次性获取文件列表和文件大小?

问题描述

我需要获取具有各自大小的文件列表。一个显而易见的方法是使用 import os,sys LINE = 'include '+ <insert_line_STRING> FILE = <insert_file_path_STRING> os.system('grep -qxF $"'+LINE+'" '+FILE+' || echo $"'+LINE+'" >> '+FILE) ,然后使用 os.listdir() 循环结果。这可以通过简单的单行代码实现:

例如:

os.path.getsize()

我想知道是否有更聪明的方法来做到这一点(例如,是否有一种标准方法可以一次性完成)?

最后,我想要做的是使用 In [1]: import os In [2]: files = {f:os.path.getsize(f) for f in os.listdir()} 显示我循环文件的进度,基于它们的大小(但我仍然需要弄清楚它是如何工作的!)。

解决方法

在我的 zsh 中使用单个命令 stat

import os
files = dict([x.split() for x in os.popen('stat -f "%z %N" *').read().split("\n")[:-1]])

当然更脏,但仍然对操作系统进行一次系统调用。