python – 获取纳秒级精度的文件修改时间

我需要为遍历文件系统树的Python 2程序中的每个文件获取完整的纳秒精度修改时间戳.我想在Python本身中这样做,因为为每个文件生成一个新的子进程会很慢.

通过查看stat结果的st_mtime_nsec字段,从Linux上的C库,you can get nanosecond-precision timestamps开始.例如:

#include <sys/stat.h>
#include <stdio.h>
int main() {
    struct stat stat_result;
    if(!lstat("/", &stat_result)) {
        printf("mtime = %lu.%lu\n", stat_result.st_mtim.tv_sec, stat_result.st_mtim.tv_nsec);
    } else {
        printf("error\n");
        return 1;
    }
}

打印mtime = 1380667414.213703287(/在ext4文件系统上,支持纳秒时间戳,时钟为UTC).

同样,日期–rfc-3339 = ns –reference = / prints 2013-10-01 22:43:34.213703287 00:00.

Python(2.7.3)的os.path.getmtime(filename)和os.lstat(filename).st_mtime将mtime作为float.但是,结果是错误的:

In [1]: import os
In [2]: os.path.getmtime('/') % 1
Out[2]: 0.21370339393615723
In [3]: os.lstat('/').st_mtime % 1
Out[3]: 0.21370339393615723

– 前6位数字是正确的,可能是由于浮点错误.

最佳答案
或者,您可以使用cffi库,它与Python 2一起使用以下代码(在LInux上测试):

from __future__ import print_function

from cffi import FFI

ffi = FFI()
ffi.cdef("""
typedef long long time_t;

typedef struct timespec {
    time_t   tv_sec;
    long     tv_nsec;
    ...;
};

typedef struct stat {
    struct timespec st_mtim;
    ...;
};

int lstat(const char *path, struct stat *buf);
""")

C = ffi.verify()

result = ffi.new("struct stat *")
p = C.lstat("foo.txt", result)
print("mtime = {0:d}.{1:09d}".format(result.st_mtim.tv_sec, result.st_mtim.tv_nsec))

这与您的问题中的C程序的行为相同.
这会产生输出:

$./test.py
mtime = 1381711568.315075616

其精度与C程序相同:

$gcc test.c -o test
$./test
mtime = 1381711568.315075616

转载注明原文:python – 获取纳秒级精度的文件修改时间 - 代码日志