如何解决使用 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]])
当然更脏,但仍然对操作系统进行一次系统调用。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。