让我举一个例子,然后试着解释一下我的问题:
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的输出,或者建议我使用另一种方法来实现这一点。
发布于 2012-10-06 05:14:56
您可以通过管道将命令发送到head -n,以限制为n行:
ls | grep srt | head -4发布于 2012-10-06 05:19:46
$ 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发布于 2012-10-06 05:28:15
如果你没有太多的文件,你可以使用bash数组:
matching_files=( *.srt )
rm "${matching_files[@]:0:4}"https://stackoverflow.com/questions/12754114
复制相似问题