回答:
を使用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
-mindepth 1
beforeを追加し-printf
ます。またsudo
、OPが必要なコンテキストで動作しないように見える場合は、この例には含めません。
-t:
この文脈では違いを作りますか?
stat -c %U *
すべてのファイルの所有者をリストします。
これは、ソートと重複がにそれをパイプによって除去することができますsort -u
。
stat -c %U * | sort -u
steeldriverが指摘したように、これは再帰的ではありません。これが求められたことを逃しました。globstarを有効にすることで再帰的にできます:
shopt -s globstar
stat -c %U **/* | sort -u
全体として、steeldriverの答えはおそらくより良く、ここで受け入れられる答えであるはずです:)
ARG_MAX
はあなたができる問題であると思いますprintf '%s\0' **/* | xargs -0 stat -c %U
(printf
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モジュールを使用して所有者のユーザー名を取得します。その後、ファイル名とユーザー名がきれいに印刷されるように結合され、コロンで区切られます。そのように動作します:
$ ./get_owners.py /etc/*
/etc/acpi:root
/etc/adduser.conf:root
/etc/alternatives:root
. . .