在 bash 中,我想提取许多文件名的一部分并将输出保存到另一个文件中。
文件格式为 Coffee_{SOME NUMBERS I WANT}.freqdist。
#!/bin/sh
for f in $(find . -name 'coffee*.freqdist)
该代码将找到所有的coffee_{SOME NUMBERS I WANT}.freqdist 文件。现在,我如何制作一个仅包含 {SOME NUMBERS I WANT} 的数组并将其写入文件?
我知道写入文件一个会以以下内容结束该行。
> log.txt
我错过了如何过滤文件名列表的中间部分。
您可以在
bash
中本地执行此操作,如下所示:
filename=coffee_1234.freqdist
tmp=${filename#*_}
num=${tmp%.*}
echo "$num"
这是一个纯粹的 bash 解决方案。不涉及外部命令(如
sed
),因此速度更快。
使用以下方法将这些数字附加到文件中:
echo "$num" >> file
(在开始循环之前,您需要删除/清除文件。)
如果只是将数字写入文件,则不需要 find 命令:
ls coffee*.freqdist
coffee112.freqdist coffee12.freqdist coffee234.freqdist
下面应该执行此操作,然后可以将其重定向到文件:
$ ls coffee*.freqdist | sed 's/coffee\(.*\)\.freqdist/\1/'
112
12
234
大师。
前面的答案已经指出了一些必要的技巧。这个答案以一种简单的方式组织管道,也可能适用于其他工作。 (如果您的
sed
不支持“;”作为分隔符,请将“;”替换为“|sed”。)
$ ls */c*; ls c*
fee/coffee_2343.freqdist
coffee_18z8.x.freqdist coffee_512.freqdist coffee_707.freqdist
$ find . -name 'coffee*.freqdist' | sed 's/.*coffee_//; s/[.].*//' > outfile
$ cat outfile
512
18z8
2343
707
扩展这个主题,假设文件名具有以下格式:
第一_第二_第三_必需文本_第四_第五_第六
要仅获取必需的文本,请使用以下命令:
filename=first_second_third_requiredText_fourth_fifth_sixth
removed_first_part=${filename#*_*_*_}
finalText=${removed_first_part%_*_*_*}
'#'从字符串的开头开始,'%'从结尾开始,'*'表示任意数量的字符。这也适用于完整路径。