在bash中,我想提取许多文件名的一部分,并将该输出保存到另一个文件中。
文件的格式为coffee_ {我想要的数字} .freqdist。
#!/bin/sh
for f in $(find . -name 'coffee*.freqdist)
该代码将找到所有coffee_ {我想要的一些数字} .freqdist文件。现在,我如何创建一个只包含{SOME NUMBERS I WANT}的数组并将其写入文件?
我知道写入文件一会以下面的结尾。
> log.txt
虽然如何过滤文件名列表,但我错过了中间部分。
答案 0 :(得分:13)
您可以在bash
中以原生方式执行此操作:
filename=coffee_1234.freqdist
tmp=${filename#*_}
num=${tmp%.*}
echo "$num"
这是一个纯粹的bash解决方案。没有涉及外部命令(如sed
),因此速度更快。
使用以下方法将这些数字附加到文件中:
echo "$num" >> file
(在开始循环之前,您需要删除/清除文件。)
答案 1 :(得分:6)
如果只想将数字写入文件,则不需要查找命令:
ls coffee*.freqdist
coffee112.freqdist coffee12.freqdist coffee234.freqdist
下面应该这样做然后可以重定向到文件:
$ ls coffee*.freqdist | sed 's/coffee\(.*\)\.freqdist/\1/'
112
12
234
师。
答案 2 :(得分: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