62

Python を使用して *nix で 644 や 755 のようなファイルのパーミッション マスクを取得するにはどうすればよいですか?

それを行うための関数またはクラスはありますか? どうもありがとうございました!

4

9 に答える 9

116

os.statstat(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'

ここから、典型的な8進数のパーミッションを認識できます。

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

あなたは本当に下のビットだけに興味があるので、残りを切り落とすことができます:

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

補足:上部はファイルタイプを決定します。例:

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)
于 2011-03-17T09:44:00.127 に答える
53

これは、ファイルの許可ビットを取得する最も明確な方法だと思います。

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))

このスクリプトは、次のように出力します。

0777
0666
于 2011-03-17T10:28:50.710 に答える
9

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
于 2011-03-17T09:36:31.660 に答える
2
oct(os.stat('file').st_mode)[4:]
于 2011-03-17T09:39:39.200 に答える
1

ディレクトリのパーミッションを確認する簡単な方法を次に示します。

import os
import stat

mode = os.stat("path_of_directory").st_mode

if not ((mode & stat.S_IWUSR):
  print('not writable by user')

if not ((mode & stat.S_IWUSR) and (mode & stat.S_IWGRP) and (mode & stat.S_IWOTH)):
  print('not writable by all')

フラグのリストは次のとおりです。

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
于 2020-08-31T14:42:03.657 に答える
1

確かにosモジュール内にはファイルベースの関数がたくさんあります。実行するos.stat(filename)と、いつでも結果を解釈できます。

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

于 2011-03-17T09:25:14.797 に答える
0

os.statc-lib stat に類似しています (Linux では man 2 stat で情報を確認できます)。

stats = os.stat('file.txt')
print(stats.st_mode)
于 2011-03-17T09:26:51.550 に答える