web-dev-qa-db-ja.com

ディレクトリ内のファイルのすべての所有者のリストを取得する方法

現在、クォータシステムを修正しようとしています。私の問題は、ディレクトリ内のすべてのファイルが同じユーザーによって所有されているかどうかを判断できないことです。可能であれば、ディレクトリ内のファイルの異なる所有者を(再帰的に)リストする方法があります。

例:get-owners-of DIRNAME

12
Jack7076

findを使用して、ユーザー(所有者)とグループを印刷し、uniqの組み合わせを抽出できます。

$ Sudo find /var -printf '%u:%g\n' | sort -t: -u
_apt:root
avahi-autoipd:avahi-autoipd
clamav:adm
clamav:clamav
colord:colord
daemon:daemon
lightdm:lightdm
lp:lp
man:root
root:adm
root:crontab
root:lp
root:mail
root:mlocate
root:root
root:shadow
root:staff
root:syslog
root:utmp
root:whoopsie
speech-dispatcher:root
statd:nogroup
steeldriver:crontab
steeldriver:lightdm
steeldriver:steeldriver
syslog:adm
systemd-timesync:systemd-timesync
testuser:crontab
23
steeldriver
stat -c %U * 

すべてのファイルの所有者をリストします。

これをソートして、sort -uにパイプすることで重複を削除できます。

stat -c %U * | sort -u

Steeldriverが指摘したように、これは再帰的ではありません。これが求められたことを逃しました。 globstarを有効にすることで再帰的にできます:

shopt -s globstar
stat -c %U **/* | sort -u

一緒に、 steeldriver's answer がおそらくより良く、ここで受け入れられた答えであるはずです:)

19
vidarlo

ファイルを直接検索する方が効率的な場合がありますnotユーザーが所有しています...

find /directory ! -user username -printf "%u %p\n" 
5
rrauenza

Python経由のDIYメソッド:

#!/usr/bin/env python3
import sys,os,pwd
for f in sys.argv[1:]:
    username = pwd.getpwuid(os.stat(f).st_uid).pw_name
    print( ":".join([f,username])  )

これは、コマンドラインにリストされているすべてのファイル名を反復処理し、ファイルの所有者のUIDを取得し、 pwd moduleを使用して所有者のユーザー名を取得します。その後、ファイル名とユーザー名がきれいに印刷されるように結合され、コロンで区切られます。そのように動作します:

$ ./get_owners.py /etc/* 
/etc/acpi:root
/etc/adduser.conf:root
/etc/alternatives:root
. . .
4