溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python3如何通過(guò)chmod修改目錄或文件權(quán)限

發(fā)布時(shí)間:2020-07-18 10:47:06 來(lái)源:億速云 閱讀:302 作者:小豬 欄目:開發(fā)技術(shù)

小編這次要給大家分享的是Python3如何通過(guò)chmod修改目錄或文件權(quán)限,文章內(nèi)容豐富,感興趣的小伙伴可以來(lái)了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

簡(jiǎn)單的介紹下linux文件權(quán)限

linux中,文件的權(quán)限分為"所有者、組、其他用戶"三個(gè)角色,每個(gè)角色由3個(gè)bit位表示它的權(quán)限,3bit從左到右分別為讀寫執(zhí)行三個(gè)權(quán)限,3bit的值范圍為0~7。所以如果直接在linux執(zhí)行chmod 777 xxx.sh代表,將xxx.sh文件賦予所有者、組、其他用戶這三個(gè)角色對(duì)xxx.sh文件的讀寫執(zhí)行權(quán)限。

os的chmod

python的os模塊負(fù)責(zé)操作系統(tǒng)層面的操作。修改文件權(quán)限可以通過(guò)os的chmod方法來(lái)操作。
os.chmod(path, mode)
方法的path指向要賦權(quán)限的文件或目錄;
mode為權(quán)限值,也就是文件權(quán)限的9位bit的10進(jìn)制數(shù),取值范圍0~511;

比如我們要將xxx.sh文件賦予所有者讀權(quán)限,其他角色沒(méi)有任何的權(quán)限,則linux中對(duì)應(yīng)的文件權(quán)限用ls -l查看為:-r---------;第一個(gè)-是文件類型,后面的9個(gè)位就代表了整個(gè)文件的權(quán)限,對(duì)應(yīng)二進(jìn)制為100000000,那么我們的mode應(yīng)該取值為256;
所以上面的權(quán)限修改代碼為os.chmod("xxx.sh",256)。

這么麻煩?

還好stat模塊提供了常量值可以直接對(duì)應(yīng)使用。

常量描述
S_IRWXU所有者讀寫執(zhí)行權(quán)限,代表值:448
S_IRUSR所有者讀,代表值:256
S_IWUSR所有者寫,代表值:128
S_IXUSR所有者執(zhí)行,代表值:64
S_IRWXG用戶組讀寫執(zhí)行權(quán)限,代表值:56
S_IRGRP用戶組讀,代表值:32
S_IWGRP用戶組寫,代表值:16
S_IXGRP用戶組執(zhí)行,代表值:8
S_IRWXO其他用戶讀寫執(zhí)行,代表值:7
S_IROTH其他用戶讀,代表值:4
S_IWOTH其他用戶寫,代表值:2
S_IXOTH其他用戶執(zhí)行,代表值:1

如下的代碼是將xxx.sh文件賦予所有者讀寫執(zhí)行、用戶組讀執(zhí)行、其他用戶讀的操作,即-rwxr-xr--:

import os
import stat

os.chmod("xxx.sh", stat.S_IRWXU+stat.S_IRGRP+stat.S_IXGRP+stat.S_IROTH)

什么?感覺(jué)常量記不?。窟€是不方便?

寫個(gè)類似chmod 777的使用方式的util吧…

import re
import os
import stat

RD, WD, XD = 4, 2, 1
BNS = [RD, WD, XD]
MDS = [
  [stat.S_IRUSR, stat.S_IRGRP, stat.S_IROTH],
  [stat.S_IWUSR, stat.S_IWGRP, stat.S_IWOTH],
  [stat.S_IXUSR, stat.S_IXGRP, stat.S_IXOTH]
]

def chmod(path, mode):
  if isinstance(mode, int):
    mode = str(mode)
  if not re.match("^[0-7]{1,3}$", mode):
    raise Exception("mode does not conform to ^[0-7]{1,3}$ pattern")
  mode = "{0:0>3}".format(mode)
  mode_num = 0
  for midx, m in enumerate(mode):
    for bnidx, bn in enumerate(BNS):
      if (int(m) & bn) > 0:
        mode_num += MDS[bnidx][midx]
  os.chmod(path, mode_num)

if __name__ == '__main__':
  chmod("xxx.sh", "744") #744代表所有者讀寫執(zhí)行,組和其他的權(quán)限只有讀

類似的你也可以讓它支持類似chmod u+rwx,g+rw,o+rw xxx.sh的使用方式。

注意:os.chmod貌似沒(méi)有辦法遞歸修改目錄下所有文件的權(quán)限?那使用下面的subprocess直接調(diào)用命令吧…

subprocess直接調(diào)用chmod命令

subprocess模塊實(shí)現(xiàn)了子進(jìn)程運(yùn)行??梢栽谧舆M(jìn)程中調(diào)用操作系統(tǒng)命令或者執(zhí)行shell,并獲取stdout、stderr。

import subprocess

if __name__ == '__main__':
  cmd = ['chmod', "-R", "777", "xxx.sh"]
  res = subprocess.run(cmd, universal_newlines=True, stdout=subprocess.PIPE,
             stderr=subprocess.PIPE, shell=False)

  print(res.returncode, res.stdout, res.stderr)

看完這篇關(guān)于Python3如何通過(guò)chmod修改目錄或文件權(quán)限的文章,如果覺(jué)得文章內(nèi)容寫得不錯(cuò)的話,可以把它分享出去給更多人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI