每天学一点儿shell:xargs 命令

2024-05-28 23:48

本文主要是介绍每天学一点儿shell:xargs 命令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、标准输入和管道
  • 二、xargs命令的作用
  • 三、xargs命令的实例
    • 1、创建多个文件目录
    • 2、多行内容变单行输出
    • 3、将内容按照","分隔
    • 4、找到所有的txt文件并压缩
    • 5、找到所有的txt文件并删除(慎用)
    • 6、配合ps和kill批量杀掉进程(实用)
    • 7、配合cp将文件拷贝到多个目录(实用)

一、标准输入和管道

举一个例子:

[root@hadoop-master test-grep]# cat -n ./file.txt | grep leo1	leo hello2	leo2 hello23	leo3 hello3

上面这个例子使用了管道命令(|),管道命令的作用是将左侧的命令(cat -n ./file.txt )的标准输出作为右边的标准输入,提供给右边的命令(grep leo)作为参数。因此上面的代码等同于如下:

[root@hadoop-master test-grep]# grep -n leo file.txt 
1:leo hello
2:leo2 hello2
3:leo3 hello3

但是大多数命令都不接收标准输入作为参数,只能直接在命令行输入参数,这导致无法用管道命令传递参数。
例如下面的语句是没有任何输出的

[root@hadoop-master test-grep]# echo "leo" | echo[root@hadoop-master test-grep]# 

二、xargs命令的作用

xargs命令的作用,是将标准输入转为命令行参数。

[root@hadoop-master test-grep]# echo "leo" | xargs  echo
leo

xargs命令格式如下:

xargs [OPTION]... COMMAND INITIAL-ARGS...

整整执行的命令是紧跟在xargs后面的COMMAND,接收xargs传来的参数
例如:

[root@hadoop-master test-grep]# echo "one two three" | xargs mkdir
[root@hadoop-master test-grep]# ll
总用量 8
drwxrwxrwx. 2 root root 22 9月  22 16:53 dir2
-rwxrwxrwx. 1 root root 60 9月  22 16:48 file2.text
-rwxrwxrwx. 1 root root 45 9月  21 23:07 file.txt
drwxr-xr-x. 2 root root  6 9月  26 17:42 one
drwxr-xr-x. 2 root root  6 9月  26 17:42 three
drwxr-xr-x. 2 root root  6 9月  26 17:42 two

上面这个命令是创建one two three 三个目录,如果不加xargs会报如下错误:

[root@hadoop-master test-grep]# echo "one two three" | mkdir
mkdir: 缺少操作数
Try 'mkdir --help' for more information.
选项解释
-afile 从文件中读入作为sdtin
-eflag ,注意有的时候可能会是-E,flag必须是一个以空格分隔的标志,当xargs分析到含有flag这个标志的时候就停止。
-p当每次执行一个argument的时候询问一次用户。
-nnum 后面加次数,表示命令在执行的时候一次用的argument的个数,默认是用所有的。
-t表示先打印命令,然后再执行。
-i或者是-I,这得看linux支持了,将xargs的每项名称,一般是一行一行赋值给 {},可以用 {} 代替。
-rno-run-if-empty 当xargs的输入为空的时候则停止xargs,不用再去执行了。
-snum 命令行的最大字符数,指的是 xargs 后面那个命令的最大命令行字符数。
-Lnum 从标准输入一次读取 num 行送给 command 命令。
-l同 -L。
-ddelim 分隔符,默认的xargs分隔符是回车,argument的分隔符是空格,这里修改的是xargs的分隔符。
-xexit的意思,主要是配合-s使用。。
-P修改最大的进程数,默认是1,为0时候为as many as it can ,这个例子我没有想到,应该平时都用不到的吧。

三、xargs命令的实例

1、创建多个文件目录

[root@hadoop-master test-grep]# echo "one two three" | mkdir

递归创建多个文件目录:

[root@hadoop-master dir1]# echo "dir1/20201011 dir2/20201011 dir3/20201011"|xargs mkdir -p

2、多行内容变单行输出

[root@hadoop-master test-grep]# cat file.txt 
leo hello
leo2 hello2
leo3 hello3
hello grep
[root@hadoop-master test-grep]# cat file.txt | xargs 
leo hello leo2 hello2 leo3 hello3 hello grep

3、将内容按照","分隔

[root@hadoop-master test-grep]# echo "leo,leo,leo" | xargs -d','
leo leo leo

4、找到所有的txt文件并压缩

[root@hadoop-master test-grep]# find . -type f -name "*.txt" -print | xargs tar -czvf txts.tar.gz
./file.txt
./dir2/file.txt

5、找到所有的txt文件并删除(慎用)

[root@hadoop-master test-grep]# find . -type f -name "*.txt" -print0 | xargs -0 rm -f

删除符合条件的目录下文件,目录结构如下,需要删除时间是20201011下的文件:

[root@hadoop-master dir1]# tree
.
├── dir1
│   └── 20201011
├── dir2
│   ├── 20201011
│   │   └── file2.txt
│   ├── 20201012
│   │   └── file2.txt
│   └── 20201013
│       └── file2.txt
└── dir3└── 20201011└── file.txt

命令如下:

[root@hadoop-master dir1]# find . -type f -name "*.txt" -print0 | grep -FzZ '20201011' | xargs -0 rm -f
[root@hadoop-master dir1]# tree
.
├── dir1
│   └── 20201011
├── dir2
│   ├── 20201011
│   ├── 20201012
│   │   └── file2.txt
│   └── 20201013
│       └── file2.txt
└── dir3└── 20201011

如果没有tree命令,可以使用yum下载一个:

[root@hadoop-master dir1]# yum install tree

6、配合ps和kill批量杀掉进程(实用)

[root@hadoop-master test-grep]# ps -ef|grep -v 'grep'|grep '测试程序'|awk '{print $2}'|xargs kill -9

7、配合cp将文件拷贝到多个目录(实用)

[root@hadoop-master BJ]# echo 20201011 20201012 20201013 | xargs -n 1 cp -v ./test01.txt 

打印结果:
图7
20201011、20201012、20201013 是三个目录,。/test01.txt代表需要复制的文件
-n 1 :表示每一个命令行只有一个参数,并且传给cp命令
cp :表示复制命令
-v:verbose表示将复制过程中的详细信息显示出来

当然可以正则匹配目录和文件名:

[root@hadoop-master dir1]# echo */20201011 | xargs -n 1 cp -v ./*.txt 
"./file1.txt" -> "dir1/20201011/file1.txt"
"./file2.txt" -> "dir1/20201011/file2.txt"
"./file1.txt" -> "dir2/20201011/file1.txt"
"./file2.txt" -> "dir2/20201011/file2.txt"
"./file1.txt" -> "dir3/20201011/file1.txt"
"./file2.txt" -> "dir3/20201011/file2.txt"

这篇关于每天学一点儿shell:xargs 命令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1012039

相关文章

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

Linux使用nohup命令在后台运行脚本

《Linux使用nohup命令在后台运行脚本》在Linux或类Unix系统中,后台运行脚本是一项非常实用的技能,尤其适用于需要长时间运行的任务或服务,本文我们来看看如何使用nohup命令在后台... 目录nohup 命令简介基本用法输出重定向& 符号的作用后台进程的特点注意事项实际应用场景长时间运行的任务服

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc