Подтвердить что ты не робот

Как я могу получить маску разрешений Unix из файла?

Как я могу получить маску разрешения файла, например 644 или 755 на * nix, используя python?

Есть ли какая-либо функция или класс для этого? Большое спасибо!

4b9b3361

Ответ 1

os.stat - это оболочка для интерфейса системных вызовов stat (2).

>>> import os
>>> from stat import *
>>> os.stat("test.txt") # returns 10-tupel, you really want the 0th element ...
posix.stat_result(st_mode=33188, st_ino=57197013, \
    st_dev=234881026L, st_nlink=1, st_uid=501, st_gid=20, st_size=0, \
    st_atime=1300354697, st_mtime=1300354697, st_ctime=1300354697)

>>> os.stat("test.txt")[ST_MODE] # this is an int, but we like octal ...
33188

>>> oct(os.stat("test.txt")[ST_MODE])
'0100644'

Отсюда вы узнаете типичные восьмеричные разрешения.

S_IRWXU 00700   mask for file owner permissions
S_IRUSR 00400   owner has read permission
S_IWUSR 00200   owner has write permission
S_IXUSR 00100   owner has execute permission
S_IRWXG 00070   mask for group permissions
S_IRGRP 00040   group has read permission
S_IWGRP 00020   group has write permission
S_IXGRP 00010   group has execute permission
S_IRWXO 00007   mask for permissions for others (not in group)
S_IROTH 00004   others have read permission
S_IWOTH 00002   others have write permission
S_IXOTH 00001   others have execute permission

Вас действительно интересуют только младшие биты, поэтому вы можете оpipeить все остальное:

>>> oct(os.stat("test.txt")[ST_MODE])[-3:]
'644'
>>> # or better
>>> oct(os.stat("test.txt").st_mode & 0o777)

Sidenote: верхние части определяют тип файла, например:

S_IFMT  0170000 bitmask for the file type bitfields
S_IFSOCK    0140000 socket
S_IFLNK 0120000 symbolic link
S_IFREG 0100000 regular file
S_IFBLK 0060000 block device
S_IFDIR 0040000 directory
S_IFCHR 0020000 character device
S_IFIFO 0010000 FIFO
S_ISUID 0004000 set UID bit
S_ISGID 0002000 set-group-ID bit (see below)
S_ISVTX 0001000 sticky bit (see below)

Ответ 2

Я думаю, что это самый лучший способ получить файл в битах разрешения:

stat.S_IMODE(os.lstat("file").st_mode)

Функция os.lstat будет в случае, если файл является символической ссылкой, даст вам режим самой ссылки, тогда как os.stat разыгрывает ссылку. Поэтому я нахожу os.lstat наиболее полезным.

Здесь примерный случай, учитывая обычный файл "testfile" и символическую ссылку на последнюю, "testlink":

import stat
import os

print oct(stat.S_IMODE(os.lstat("testlink").st_mode))
print oct(stat.S_IMODE(os.stat("testlink").st_mode))

Этот script выводит для меня следующее:

0777
0666

Ответ 3

Другой способ сделать это, если вы не хотите выяснить, что означает stat, - использовать команду os.access http://docs.python.org/library/os.html#os.access НО читайте документы о возможных проблемах безопасности

Например, для проверки прав доступа к файлу test.dat, который имеет права на чтение/запись

os.access("test.dat",os.R_OK)
>>> True

#Execute permissions
os.access("test.dat",os.X_OK)
>>> False

#And Combinations thereof
os.access("test.dat",os.R_OK or os.X_OK)
>>> True

os.access("test.dat",os.R_OK and os.X_OK)
>>> False

Ответ 4

Октябрь (os.stat( 'файл') st_mode.) [4:]

Ответ 5

Внутри модуля os много функций на основе файлов. Если вы запустите os.stat(filename), вы всегда можете совместить результаты.

http://docs.python.org/library/stat.html

Ответ 6

os.stat аналогичен c-lib stat (man 2 stat on linux для просмотра информации)

stats = os.stat('file.txt')
print stats.st_mode

Ответ 7

Метод os.access(path, mode) возвращает True, если доступ разрешен по пути, и False, если нет.

Доступны следующие режимы:

  1. os.F_OK - проверить существование пути.
  2. os.R_OK - проверить читаемость пути.
  3. os.W_OK - проверить возможность записи пути.
  4. os.X_OK - проверить, можно ли выполнить путь.

например, проверка файла /tmp/test.sh имеет разрешение на выполнение

ls -l /tmp/temp.sh
-rw-r--r--  1 *  *  0 Mar  2 12:05 /tmp/temp.sh

os.access('/tmp/temp.sh',os.X_OK)
False

after changing the file permission to +x 
chmod +x /tmp/temp.sh

ls -l /tmp/temp.sh
-rwxr-xr-x  1 *  *  0 Mar  2 12:05 /tmp/temp.sh

os.access('/tmp/temp.sh',os.X_OK)
True

Ответ 8

Вы можете просто запустить команду Bash stat с Popen, если хотите:

Обычная команда Bash:

[email protected]:~/NetBeansProjects/LineReverse$ stat -c '%A %a %n' revline.c
-rw-rw-r-- 664 revline.c

А потом с Python:

>>> from subprocess import Popen, PIPE
>>> fname = 'revline.c'
>>> cmd = "stat -c '%A %a %n' " + fname
>>> out = Popen(cmd, shell=True, stdout=PIPE).communicate()[0].split()[1].decode()
>>> out
'664'

А вот и другой способ, если вам хочется искать в каталоге:

>>> from os import popen
>>> cmd = "stat -c '%A %a %n' *"
>>> fname = 'revline.c'
>>> for i in popen(cmd):
...     p, m, n = i.split()
...     if n != fname:
...         continue
...     print(m)
        break
... 
664
>>>