最近我从svn上checkout出来了一个文件夹,而后加入了git的跟踪目录.用过svn的同窗可能知道,这个文件夹里面每一层级都有个.svn隐藏文件夹,须要删除他们.原本我准备笨拙地一个一个手动删除的,一位同事在我面前敲了大概是$find . -type d -name "*.svn" | xargs rm -rf
这样的命令,顿时以为很高端大气上档次.恰好新学了Markdown,就顺便整理下xargs的用法,练练手.参考网址,固然更主要的参考来自于伟大的$man xargs
.html
xargs
从标准输入(stdin)中读取数据进行处理git
/bin/echo
下面咱们来看看xargs
有哪些参数能够选择.svn
$cat 1.txt aaa bbb ccc ddd a b $xargs -a 1.txt aaa bbb ccc ddd a b
$echo "// " | xargs // $echo "// " | xargs -0 //
$cat 1.txt aaa bbb ccc ddd a b $cat 1.txt | xargs -d 'c' aaa bbb ddd a b
eof-str
,xargs
处理到这个标志就会中止$xargs -E 'ddd' -a 1.txt aaa bbb ccc $xargs -E 'dd' -a 1.txt aaa bbb ccc ddd a b $cat 1.txt | xargs -E 'ddd' aaa bbb ccc
replace-str
$cat 1.txt aaa bbb ccc ddd a b $cat 1.txt | xargs -t -I {} echo {} >> 1.txt echo aaa bbb ccc ddd echo a b $cat 1.txt aaa bbb ccc ddd a b aaa bbb ccc ddd a b
-I{}
$cat 1.txt aaa bbb ccc ddd a b $cat 1.txt | xargs -t -i echo {} >> 1.txt echo aaa bbb ccc ddd echo a b $cat 1.txt aaa bbb ccc ddd a b aaa bbb ccc ddd a b
max-line
行输入交由xargs
处理$cat 1.txt aaa bbb ccc ddd a b $cat 1.txt |xargs -L 2 aaa bbb ccc ddd a b $cat 1.txt |xargs -L 1 aaa bbb ccc ddd a b
-l
: 相似于-L
,区别在于-l
能够不指定参数,默认为1.性能
max-args
个输入,默认执行全部$cat 1.txt | xargs -n 2 aaa bbb ccc ddd a b
$cat 1.txt | xargs -p /bin/echo aaa bbb ccc ddd a b ?...y aaa bbb ccc ddd a b $cat 1.txt | xargs -p /bin/echo aaa bbb ccc ddd a b ?...n
$ echo ""|xargs -t mv mv mv: missing file operand Try `mv --help` for more information. $ echo ""|xargs -t -r mv #直接退出
xargs
每次执行命令的最大长度(含空格)$ cat 1.txt aaa bbb ccc ddd a b $ cat 1.txt |xargs -t -s 30 /bin/echo aaa bbb ccc ddd a b aaa bbb ccc ddd a b #length(/bin/echo aaa bbb ccc ddd a b )=30 $cat 1.txt |xargs -t -s 14 /bin/echo aaa aaa /bin/echo bbb bbb /bin/echo ccc ccc /bin/echo ddd ddd /bin/echo a b a b #length(/bin/echo aaa )=14
$cat 1.txt | xargs -t /bin/echo aaa bbb ccc ddd a b aaa bbb ccc ddd a b
-x
: 当xargs
执行的命令长度大于-s max-char
时,中止执行测试
-P max-procs
: 修改线程数,默认为单线程.max-procs
为0时,as many processes as possible
ui
在使用find命令的-exec选项处理匹配到的文件时,find命令将全部匹配到的文件一块儿传递给exec执行。但有些系统对可以传递给exec的命令长度有限制,这样在find命令运行几分钟以后,就会出现溢出错误。错误信息一般是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一块儿使用。find命令把匹配到的文件 传递给xargs命令,而xargs命令每次只获取一部分文件而不是所有,不像-exec选项那样。这样它能够先处理最早获取的一部分文件,而后是下一 批,并如此继续下去。
在有些系统中,使用-exec选项会为处理每个匹配到的文件而发起一个相应的进程,并不是将匹配到的文件所有做为参数一次执行;这样在有些状况下就会出现进程过多,系统性能降低的问题,于是效率不高;而使用xargs命令则只有一个进程。另外,在使用xargs命令时,到底是一次获取全部的参数,仍是分批取得参数,以及每一次获取参数的数目 都会根据该命令的选项及系统内核中相应的可调参数来肯定。
管道是把一个命令的输出传递给另外一个命令做为输入,好比:command1 | command2
可是command2仅仅把command1输出的内容做为输入参数。find . -name "install.log" -print
打印出的是install.log这个字符串,若是仅仅使用管道,那么command2可以使用的仅仅是install.log这个字符串,不能把它看成文件来进行处理。
固然这个command2除了xargs。xargs就是为了可以对find搜索到的文件进行操做而编写的。它能把管道传来的字符串看成文件交给其后的命令执行。.net
$find . -name "1.txt" | cat ./1.txt #显示从管道传来的内容,仅仅做为字符串来处理
$find . -name "1.txt" | xargs cat aaa bbb ccc ddd a b #将管道传来的内容做为文件,交给cat执行。也就是说,该命令执行的是若是存在1.txt,那么就打印出这个文件的内容。
$find . -perm -7 -print | xargs chmod o-w #在当前目录下查找全部用户具备读、写和执行权限的文件,并收回相应的写权限
$ find . -type f -print | xargs file #查找系统中的每个普通文件,而后使用xargs命令来测试它们分别属于哪类文件
$find ~ -name '*.log' -print0 | xargs -i -0 rm -f {} #尝试用rm 删除太多的文件,你可能获得一个错误信息:/bin/rm Argument list too long. 用xargs 去避免这个问题
$find / -name *.jpg -type f -print | xargs tar -cvzf images.tar.gz #查找全部的jpg 文件,而且压缩它
$ls *.jpg | xargs -n 1 -i cp {} /external-hard-drive/directory #拷贝全部的图片文件到一个外部的硬盘驱动
这里只是最简略的用法,目的是快速理解上手使用.若是遇到问题,请使用man xargs
或者拨打10086
:)线程
特别鸣谢:
http://blog.csdn.net/zhangfn2011/article/details/6776925
http://blog.csdn.net/hittata/article/details/8021500
http://www.cnblogs.com/wdpp/archive/2012/02/28/2386683.html
http://blog.163.com/ly_89/blog/static/18690229920117208314257/
http://aix.chinaunix.net/doc/2008/03/01/1108340.shtml
http://blog.chinaunix.net/uid-15117916-id-4920.htmlunix