提取文件名 shell 脚本的一部分

问题描述 投票:0回答:4

在 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 shell
4个回答
17
投票

您可以在

bash
中本地执行此操作,如下所示:

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

这是一个纯粹的 bash 解决方案。不涉及外部命令(如

sed
),因此速度更快。

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

echo "$num" >> file

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


7
投票

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

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

下面应该执行此操作,然后可以将其重定向到文件:

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

大师。


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

0
投票

扩展这个主题,假设文件名具有以下格式:

第一_第二_第三_必需文本_第四_第五_第六

要仅获取必需的文本,请使用以下命令:

filename=first_second_third_requiredText_fourth_fifth_sixth
removed_first_part=${filename#*_*_*_}
finalText=${removed_first_part%_*_*_*}

'#'从字符串的开头开始,'%'从结尾开始,'*'表示任意数量的字符。这也适用于完整路径。

© www.soinside.com 2019 - 2024. All rights reserved.