问题描述
我需要获取具有各自大小的文件列表。一个显而易见的方法是使用 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]])
当然更脏,但仍然对操作系统进行一次系统调用。