gpt4 book ai didi

LINUX - shell 脚本查找并列出所有有权在目录树中写入的文件

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:20:18 25 4
gpt4 key购买 nike

这是我到目前为止的代码:

echo $(pwd > adress)
var=$(head -1 adress)
rm adress

found=0 #Flag
fileshow()
{
cd $1
for i in *
do
if [ -d $i ]
then
continue
elif [ -w $i ]
then
echo $i
found=1
fi
done
cd ..
}
fileshow $1

if [ $found -eq 0 ]
then
clear
echo "$(tput setaf 1)There arent any executable files !!!$(tput sgr0)"
fi

它可以工作,但它只能在当前目录中找到文件。

我被告知我需要使用某种递归方法来遍历所有子目录,但我不知道该怎么做。

所以,如果有人能帮助我,我将不胜感激。

谢谢!

最佳答案

您的脚本的作用是找到当前工作目录下不是目录但对当前用户可写的文件。这可以通过命令实现:

find ./ -type f -writable

使用 -type f 的优点是它还可以排除符号链接(symbolic link)和其他特殊类型的文件,如果您需要的话。如果你想要所有不是目录的文件(如你的脚本所建议的),那么你可以使用:

find ./ ! -type d -writable

如果你想对这些文件进行排序(添加问题,假设字典升序),你可以使用sort:

find ./ -type f -writable | sort

如果您想将这些排序后的文件名用于其他用途,规范模式将是(处理带有嵌入换行符和其他很少使用的字符的文件名):

while read -r -d $'\0'; do
echo "File '$REPLY' is an ordinary file and is writable"
done < <(find ./ -type f -writable -print0 | sort -z)

如果您使用的是非常旧的 find 版本,它不支持方便的 -writable 谓词 (added to v.4.3 in 2005),那么您只有文件权限继续。然后,您必须清楚在特定上下文中“可写”的含义(可写给谁?),并且您可以将 -writable 谓词替换为 -perm @gregb 的回答中描述的谓词。如果你决定你的意思是“任何人都可以写”,你可以使用 -perm/u=w,g=w,o=w-perm/222,但是有实际上,仅使用权限无法获得 -writable 的所有好处。另请注意,+ 形式的 -perm 权限测试已弃用,不应再使用;应改用 / 形式。

关于LINUX - shell 脚本查找并列出所有有权在目录树中写入的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22867324/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com