你如何在python中做一个简单的“chmod + x”?

时间:2012-10-09 02:18:48

标签: python chmod

我想在可执行的python脚本中创建一个文件。

import os
import stat
os.chmod('somefile', stat.S_IEXEC)

似乎os.chmod没有像unix chmod那样'添加'权限。注释掉最后一行后,该文件具有filemode -rw-r--r--,如果没有注释掉,则文件模式为---x------。如何在保持其余模式完整的同时添加u+x标志?

7 个答案:

答案 0 :(得分:157)

使用os.stat()获取当前权限,将|或位一起使用,并使用os.chmod()设置更新的权限。

示例:

import os
import stat

st = os.stat('somefile')
os.chmod('somefile', st.st_mode | stat.S_IEXEC)

答案 1 :(得分:16)

对于生成可执行文件(例如脚本)的工具,以下代码可能会有所帮助:

def make_executable(path):
    mode = os.stat(path).st_mode
    mode |= (mode & 0o444) >> 2    # copy R bits to X
    os.chmod(path, mode)

这使得它(或多或少)尊重创建文件时生效的umask:只为那些可以读取的文件设置了可执行文件。

用法:

path = 'foo.sh'
with open(path, 'w') as f:           # umask in effect when file is created
    f.write('#!/bin/sh\n')
    f.write('echo "hello world"\n')

make_executable(path)

答案 2 :(得分:6)

如果您知道所需的权限,那么以下示例可能是保持简单的方法。

Python 2:

i

Python 3:

os.chmod("/somedir/somefile", 0775)

兼容(八进制转换):

os.chmod("/somedir/somefile", 0o775)

参考permissions examples

答案 3 :(得分:2)

你也可以这样做

>>> import os
>>> st = os.stat("hello.txt")

文件的当前列表

$ ls -l hello.txt
-rw-r--r--  1 morrison  staff  17 Jan 13  2014 hello.txt

现在这样做。

>>> os.chmod("hello.txt", st.st_mode | 0o111)

你会在终端看到这个。

ls -l hello.txt    
-rwxr-xr-x  1 morrison  staff  17 Jan 13  2014 hello.txt

您可以按位或使用0o111使所有可执行文件,0o222使所有可写,0o444使所有可读。

答案 4 :(得分:0)

在python3中:

import os
os.chmod("somefile", 0o664)

请记住要添加0o前缀,因为权限设置为八进制整数,并且Python会自动将前导零的任何整数视为八进制。否则,您确实传递了os.chmod("somefile", 1230)的八进制664

答案 5 :(得分:0)

umask一样尊重chmod +x

man chmod说,如果没有给出augo,如下所示:

chmod +x mypath

然后aumask一起使用:

  

字母ugoa的组合控制将更改哪些用户对该文件的访问权限:拥有该文件的用户(u),该文件组中的其他用户(g),不在该文件组中的其他用户(o) ,或所有用户(a)。如果没有给出这些,则效果就好像给出了(a)一样,但不影响umask中设置的位。

这里是一个完全模拟该行为的版本:

#!/usr/bin/env python3

import os
import stat

def get_umask():
    umask = os.umask(0)
    os.umask(umask)
    return umask

def chmod_plus_x(path):
    os.chmod(
        path,
        os.stat(path).st_mode |
        (
            (
                stat.S_IXUSR |
                stat.S_IXGRP |
                stat.S_IXOTH
            )
            & ~get_umask()
        )
    )

chmod_plus_x('.gitignore')

另请参阅:How can I get the default file permissions in Python?

在Ubuntu 16.04,Python 3.5.2中进行了测试。

答案 6 :(得分:0)

如果您使用的是Python 3.4+,则可以使用标准库的便捷pathlib

Path类具有内置的chmodstat方法。

from pathlib import Path


f = Path("/path/to/file.txt")
f.chmod(f.stat().st_mode | stat.S_IEXEC)