让我举一个例子,而不是尝试解释我的问题:
noob@noob:~/Downloads$ ls | grep srt$
Elementary - 01x01 - Pilot.LOL.English.HI.C.orig.Addic7ed.com.srt
Haven - 01x01 - Welcome to Haven.DVDRip.SAiNTS.English.updated.Addic7ed.com.srt
Haven - 01x01 - Welcome to Haven.FQM.English.HI.C.updated.Addic7ed.com.srt
Supernatural - 08x01 - We Need to Talk About Kevin.LOL.English.HI.C.updated.Addic7ed.com.srt
The Big Bang Theory - 06x02 - The Decoupling Fluctuation.LOL.English.HI.C.orig.Addic7ed.com.srt
Torchwood - 1x01 - Everything changes.0TV.English.orig.Addic7ed.com.srt
Torchwood - 1x01 - Everything changes.divx.English.updated.Addic7ed.com.srt
现在我只想删除上述命令的前four results
。通常,如果我必须删除所有文件,我会ls | grep srt$ | xargs -I {} rm {}
但在这种情况下,我只想删除前四个文件。
那么,如何限制 ls 和 grep 的输出或向我建议另一种方法来实现这一目标。
您可以将
命令通过管道传输到head -n
以限制为n
行:
ls | grep srt | head -4
$ for i in `seq 1 345`; do echo $i ;done | sed -n '1,4p'
1
2
3
4
geee: ~
$ for i in `seq 1 345`; do echo $i ;done | sed -n '335,360p'
335
336
337
338
339
340
341
342
343
344
345
如果没有太多文件,可以使用bash
数组:
matching_files=( *.srt )
rm "${matching_files[@]:0:4}"