как найти владельца файла или каталога в python

Мне нужна функция или метод в Python, чтобы найти владельца файла или каталога.

Функция должна быть такой:

>>> find_owner("/home/somedir/somefile")
owner3

person ramdaz    schedule 02.12.2009    source источник


Ответы (7)


Я не особо разбираюсь в питоне, но мне удалось это сделать:

from os import stat
from pwd import getpwuid

def find_owner(filename):
    return getpwuid(stat(filename).st_uid).pw_name
person asveikau    schedule 02.12.2009
comment
Обратите внимание, что os.stat() по умолчанию не работает с символическими ссылками. Чтобы получить симлинки, вам нужно передать параметр follow_symlinks=False. - person gye; 26.07.2019
comment
Это решение только для Unix? - person xjcl; 02.03.2021

Вы хотите использовать os.stat():

os.stat(path)
 Perform the equivalent of a stat() system call on the given path. 
 (This function follows symlinks; to stat a symlink use lstat().)

The return value is an object whose attributes correspond to the 
members of the stat structure, namely:

- st_mode - protection bits,
- st_ino - inode number,
- st_dev - device,
- st_nlink - number of hard links,
- st_uid - user id of owner,
- st_gid - group id of owner,
- st_size - size of file, in bytes,
- st_atime - time of most recent access,
- st_mtime - time of most recent content modification,
- st_ctime - platform dependent; time of most recent metadata 
             change on Unix, or the time of creation on Windows)

Пример использования для получения UID владельца:

from os import stat
stat(my_filename).st_uid

Однако обратите внимание, что stat возвращает номер идентификатора пользователя (например, 0 для root), а не фактическое имя пользователя.

person Kurt    schedule 02.12.2009

Это старый вопрос, но для тех, кто ищет более простое решение с Python 3.

Вы также можете использовать Path из pathlib для решения этой проблемы, вызывая методы owner и group Path следующим образом:

from pathlib import Path

path = Path("/path/to/your/file")
owner = path.owner()
group = path.group()
print(f"{path.name} is owned by {owner}:{group}")

Таким образом, в этом случае метод может быть следующим:

from typing import Union
from pathlib import Path

def find_owner(path: Union[str, Path]) -> str:
    path = Path(path)
    return f"{path.owner()}:{path.group()}"
person Gábor    schedule 01.04.2020

Недавно я наткнулся на это, пытаясь получить информацию о пользователе-владельце и группе, поэтому я решил поделиться тем, что придумал:

import os
from pwd import getpwuid
from grp import getgrgid

def get_file_ownership(filename):
    return (
        getpwuid(os.stat(filename).st_uid).pw_name,
        getgrgid(os.stat(filename).st_gid).gr_name
    )
person Will    schedule 06.08.2016

Вот пример кода, показывающий, как можно найти владельца файла:

#!/usr/bin/env python
import os
import pwd
filename = '/etc/passwd'
st = os.stat(filename)
uid = st.st_uid
print(uid)
# output: 0
userinfo = pwd.getpwuid(st.st_uid)
print(userinfo)
# output: pwd.struct_passwd(pw_name='root', pw_passwd='x', pw_uid=0, 
#          pw_gid=0, pw_gecos='root', pw_dir='/root', pw_shell='/bin/bash')
ownername = pwd.getpwuid(st.st_uid).pw_name
print(ownername)
# output: root
person unutbu    schedule 02.12.2009

См. os.stat. Это дает вам st_uid, который является идентификатором пользователя владельца. Затем вы должны преобразовать его в имя. Для этого используйте pwd.getpwuid.

person Craig McQueen    schedule 02.12.2009

В Windows это работает, но использует cli

import os
from subprocess import Popen, PIPE
from collections import namedtuple


def sliceit(iterable, tup):
    return iterable[tup[0]:tup[1]].strip()

def convert_cat(line):
    # Column Align Text indicies from cmd
    # Date time dir filesize owner filename
    Stat = namedtuple('Stat', 'date time directory size owner filename')
    stat_index = Stat(date=(0, 11), 
                      time=(11, 18), 
                      directory=(18, 27), 
                      size=(27, 35), 
                      owner=(35, 59), 
                      filename=(59, -1))

    stat = Stat(date=sliceit(line, stat_index.date),
                      time=sliceit(line, stat_index.time),
                      directory=sliceit(line, stat_index.directory),
                      size=sliceit(line, stat_index.size),
                      owner=sliceit(line, stat_index.owner),
                      filename=sliceit(line, stat_index.filename))
    return stat

def stat(path):
    if not os.path.isdir(path):
        dirname, filename = os.path.split(path)
    else:
        dirname = path
    cmd = ["cmd", "/c", "dir", dirname, "/q"]
    session = Popen(cmd, stdin=PIPE, stdout=PIPE, stderr=PIPE)
    # cp1252 is common on my Norwegian Computer,
    # check encoding from your windows system
    result = session.communicate()[0].decode('cp1252')

    if os.path.isdir(path):
        line = result.splitlines()[5]
        return convert_cat(line)
    else:
        for line in result.splitlines()[5:]:
            if filename in line:
                return convert_cat(line)
        else:
            raise Exception('Could not locate file')

if __name__ == '__main__':
    print(stat('C:\\temp').owner)
    print(stat('C:\\temp\\diff.py'))
person Paal Pedersen    schedule 15.01.2020