Используйте свойство st_birthtime
в результате вызова os.stat()
(или fstat
/ lstat
).
def get_creation_time(path):
return os.stat(path).st_birthtime
Вы можете преобразовать целочисленный результат в объект даты и времени, используя datetime.datetime.fromtimestamp()
.
Почему-то я не думаю, что это работало на Mac OS X, когда этот ответ был впервые написан, но я могу ошибаться, и теперь это работает, даже с более старыми версиями Python. Старый ответ ниже для потомков.
Использование ctypes
для доступа к системному вызову stat64
(работает с Python 2.5 +):
from ctypes import *
class struct_timespec(Structure):
_fields_ = [('tv_sec', c_long), ('tv_nsec', c_long)]
class struct_stat64(Structure):
_fields_ = [
('st_dev', c_int32),
('st_mode', c_uint16),
('st_nlink', c_uint16),
('st_ino', c_uint64),
('st_uid', c_uint32),
('st_gid', c_uint32),
('st_rdev', c_int32),
('st_atimespec', struct_timespec),
('st_mtimespec', struct_timespec),
('st_ctimespec', struct_timespec),
('st_birthtimespec', struct_timespec),
('dont_care', c_uint64 * 8)
]
libc = CDLL('libc.dylib') # or /usr/lib/libc.dylib
stat64 = libc.stat64
stat64.argtypes = [c_char_p, POINTER(struct_stat64)]
def get_creation_time(path):
buf = struct_stat64()
rv = stat64(path, pointer(buf))
if rv != 0:
raise OSError("Couldn't stat file %r" % path)
return buf.st_birthtimespec.tv_sec
Использование subprocess
для вызова утилиты stat
:
import subprocess
def get_creation_time(path):
p = subprocess.Popen(['stat', '-f%B', path],
stdout=subprocess.PIPE, stderr=subprocess.PIPE)
if p.wait():
raise OSError(p.stderr.read().rstrip())
else:
return int(p.stdout.read())