[英]Extract part of a filename shell script
在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
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.