温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

[白开水]-shell-xargs知识总结-知识点

发布时间:2020-04-10 01:20:34 来源:网络 阅读:1368 作者:vekergu 栏目:开发技术


管道是实现"将前面的标准输出作为后面的标准输入"

xargs是实现"将标准输入作为命令的参数"


对比:

ind /sbin -perm +700 |ls -l

find /sbin -perm +700 |xargs ls -l


参数及用法:

-0 :当sdtin含有特殊字元时候,将其当成一般字符,像/''空格等

# echo "/ /  "|xargs -0 echo > aaa
# echo "/ /  "|xargs echo > bbb
# cat -A aaa
/ /  $
$
# cat -A bbb
/ /$

-a file 从文件中读入作为sdtin

$ cat>1.txt<<EOF 
aaa  bbb ccc ddd
a    b
EOF
$ xargs -a 1.txt echo
aaa bbb ccc ddd a b

-e flag ,注意有的时候可能会是-E,flag必须是一个以空格分隔的标志,当xargs分析到含有flag这个标志的时候就停止。

#使用小e参数,会出现等待输入,建议使用大E

$ xargs -E 'ddd'  -a 1.txt echo
aaa bbb ccc
$ cat 1.txt |xargs -E 'ddd' echo
aaa bbb ccc

-n num 后面加次数,表示命令在执行的时候一次用的argument的个数,默认是用所有的。

$ cat 1.txt |xargs -n 2 echo
aaa bbb
ccc ddd
a b

#如果将所有filed排成一列

$ cat 1.txt |xargs -n 1

-r  no-run-if-empty 如果没有要处理的参数传递给xargsxargs 默认是带 空参数运行一次,如果你希望无参数时,停止 xargs,直接退出,使用 -r 选项即可,其可以防止xargs 后面命令带空参数运行报错。

$ echo ""|xargs -t mv
mv 
mv: missing file operand
Try 'mv --help' for more information.
$ echo ""|xargs -t -r mv         #直接退出

-s num xargs后面那个命令的最大命令行字符数(含空格)

$ cat 1.txt.bak |xargs  -s 9 echo
aaa
bbb
ccc
ddd
a b
$ cat 1.txt.bak |xargs  -s 4 echo
xargs: can not fit single argument within argument list size limit      #length(echo)=4
$ cat 1.txt.bak |xargs  -s 8 echo
xargs: argument line too long      #length(echo)=4,length(aaa)=3,length(null)=1,total_length=8

-i 或者是-I,这得看linux支持了,将xargs的每项名称,一般是一行一行赋值给{},可以用{}代替。

$ ls
1.txt  2.txt  3.txt  log.xml
$ ls *.txt |xargs -t -i mv {} {}.bak
mv 1.txt 1.txt.bak 
mv 2.txt 2.txt.bak 
mv 3.txt 3.txt.bak 
$ ls
1.txt.bak  2.txt.bak  3.txt.bak  log.xml

注意,-I 必须指定替换字符 -i 是否指定替换字符-可选

find . | xargs -I {} cp {} $D_PATH

find . | xargs -i cp {} $D_PATH

注意:cshell和tcshell中,需要将{}用单引号、双引号或反斜杠,否则不认识。bash可以不用。

find /shell -maxdepth 2 -name a -print | xargs -t -i sed -i '1 i\111' '{}'

-p 操作具有可交互性,每次执行comand都交互式提示用户选择,当每次执行一个argument的时候询问一次用户

$ cat 1.txt |xargs -p echo
echo aaa bbb ccc ddd a b ?...y
aaa bbb ccc ddd a b
$ cat 1.txt |xargs -p echo
echo aaa bbb ccc ddd a b ?...n

-t 表示先打印命令,然后再执行。

$ cat 1.txt |xargs -t echo
echo aaa bbb ccc ddd a b 
aaa bbb ccc ddd a b

-L  从标准输入一次读取num行送给Command命令 ,-l和-L功能一样

$ cat 1.txt.bak 
aaa bbb ccc ddd
a b
ccc
dsds
$ cat 1.txt.bak |xargs  -L 4 echo
aaa bbb ccc ddd a b ccc dsds
$ cat 1.txt.bak |xargs  -L 1 echo
aaa bbb ccc ddd
a b
ccc
dsds

-d delimter 分隔符,默认的xargs分隔符是回车,argument的分隔符是空格,这里修改的是xargs的分隔符

$ cat 1.txt.bak
aaa@ bbb ccc@ ddd
a b
$ cat 1.txt.bak|xargs  -d '@' echo
aaa  bbb ccc ddd
a b

-x exit的意思,如果有任何 Command 行大于 -s Size 标志指定的字节数,停止运行 xargs 命令,-L -I -n 默认打开-x参数,主要是配合-s使用

 

-P 修改最大的进程数,默认是1,为0时候为as manyas it can

 

实例用法:

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错误
find / -name *.jpg-type f -print | xargs tar -cvzf p_w_picpaths.tar.gz #查找所有的jpg 文件,并且压缩它
ls *.jpg | xargs-n1 -i cp {} /external-hard-drive/directory          #拷贝所有的图片文件到一个外部的硬盘驱动
find / -perm +7000 | xargs ls -l                    # 将前面的内容,作为后面命令的参数
seq 1 10 |xargs  -i date -d "{} days "+%Y-%m-%d   # 列出10天日期
seq 1 10 |xargs  -i touch "{}.txt"                #一次生成10个空文件
cat a.txt | xargs           # 列转行
cat a.txt | xargs -n1       # 行转列
find .|xargs grep -ri"192.168.1.112"      #找出目下下所有文件包含192.168.1.112的字符
 
ssh -n $ip 'find '$path' /data /opt -typef  -name "*.sh" -or -name"*.py" -or -name "*.pl" |xargs tar zcvpf /tmp/data_backup.tar.gz'
#远程打包


 

参考:

http://czmmiao.iteye.com/blog/1949225

http://blog.csdn.net/yhcharles/article/details/44875865

http://blog.csdn.net/zhangfn2011/article/details/6776925/

http://blog.csdn.net/yongan1006/article/details/8134581

http://czmmiao.iteye.com/blog/1949225

http://www.cnblogs.com/perfy/archive/2012/07/24/2606101.html


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI