这与这个问题类似,但是我想包含相对于unix中当前目录的路径。如果我这样做:
ls -LR | grep .txt
它不包括完整路径。例如,我有如下的目录结构:
test1/file.txt
test2/file1.txt
test2/file2.txt
上面的代码将返回:
file.txt
file1.txt
file2.txt
如何使用标准Unix命令让它包含相对于当前目录的路径?
这与这个问题类似,但是我想包含相对于unix中当前目录的路径。如果我这样做:
ls -LR | grep .txt
它不包括完整路径。例如,我有如下的目录结构:
test1/file.txt
test2/file1.txt
test2/file2.txt
上面的代码将返回:
file.txt
file1.txt
file2.txt
如何使用标准Unix命令让它包含相对于当前目录的路径?
当前回答
使用树,带-f(全路径)和-i(无缩进行):
tree -if --noreport .
tree -if --noreport directory/
然后您可以使用grep过滤出您想要的。
如果没有找到命令,可以安装:
在RHEL/CentOS和Fedora linux下,输入以下命令安装树命令:
# yum install tree -y
如果你使用Debian/Ubuntu,在你的终端输入以下命令:
$ sudo apt-get install tree -y
其他回答
试着找到。你可以在手册页中找到它,但它是这样的:
查找[起始目录]-name[查找内容]
举个例子
找到。- name " * . txt "
应该给你你想要的。
使用找到:
find . -name \*.txt -print
在使用GNU find的系统上,比如大多数GNU/Linux发行版,您可以省略-print。
您可以像这样实现此功能 首先,使用ls命令指向目标目录。稍后使用find命令过滤它的结果。 从你的情况来看,文件名总是以单词开头 * * * . txt的文件
ls /some/path/here | find . -name 'file*.txt' (* represents some wild card search)
你可以创建一个shell函数,例如在你的.zshrc或.bashrc中:
filepath() {
echo $PWD/$1
}
filepath2() {
for i in $@; do
echo $PWD/$i
done
}
显然,第一个只适用于单个文件。
这很管用:
ls -R1 $PWD |当读取l;*) d=${l%:};;" ") d =;;*)返回"$d/$l";;esac;完成| grep -i ".txt"
但是它通过ls的解析“犯罪”来做到这一点,尽管这被GNU和Ghostscript社区认为是糟糕的形式。