7

在 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

我错过了如何过滤文件名列表的中间部分。

4

3 回答 3

14

您可以bash按以下方式本地执行此操作:

filename=coffee_1234.freqdist
tmp=${filename#*_}
num=${tmp%.*}
echo "$num"

这是一个纯粹的 bash 解决方案。不涉及外部命令(如sed),因此速度更快。

使用以下命令将这些数字附加到文件中:

echo "$num" >> file

(您需要在开始循环之前删除/清除文件。)

于 2012-09-25T11:47:38.337 回答
6

如果目的只是将数字写入文件,则不需要 find 命令:

ls coffee*.freqdist
coffee112.freqdist  coffee12.freqdist  coffee234.freqdist

下面应该这样做,然后可以将其重定向到文件:

$ ls coffee*.freqdist | sed 's/coffee\(.*\)\.freqdist/\1/'
112
12
234

大师。

于 2012-09-25T11:42:58.253 回答
1

以前的答案已经表明了一些必要的技术。这个答案以一种简单的方式组织了管道,也可能适用于其他工作。(如果您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
于 2012-09-25T15:29:14.640 回答