Answers:
您可以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
之前添加-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
. . .