Linux基础:xargs命令

简介

xargs可以将输入内容(通常通过命令行管道传递),转成后续命令的参数,通常用途有:

  1. 命令组合:尤其是一些命令不支持管道输入,比如ls
  2. 避免参数过长:xargs可以通过-nx来将参数分组,避免参数过长。

使用语法如下

Usage: xargs [OPTION]... COMMAND INITIAL-ARGS...
Run COMMAND with arguments INITIAL-ARGS and more arguments read from input.

入门例子

首先,创建测试文件

touch a.js b.js c.js

接着,运行如下命令:

ls *.js | xargs ls -al

输出如下:

-rw-r--r--  1 a  wheel  0 12 18 16:18 a.js
-rw-r--r--  1 a  wheel  0 12 18 16:18 b.js
-rw-r--r--  1 a  wheel  0 12 18 16:18 c.js

命令解释:

  1. 首先,ls *.js的输出为a.js b.js c.js
  2. 通过管道,将a.js b.js c.js作为xargs的输入参数。
  3. xargs命令收到输入参数后,对参数进行解析,以空格/换行作为分隔符,拆分成多个参数,这里变成a.jsb.jsc.js
  4. xargs将拆分后的参数,传递给后续的命令,作为后续命令的参数,也就是说,组成这样的命令ls -al a.js b.js c.js

可以加上-t参数,在执行后面的命令前,先将命令打印出来。

ls *.js | xargs -t ls -al

输出如下,可以看到多了一行内容ls -al a.js b.js c.js,这就是实际运行的命令。

ls -al a.js b.js c.js
-rw-r--r--  1 a  wheel  0 12 18 16:18 a.js
-rw-r--r--  1 a  wheel  0 12 18 16:18 b.js
-rw-r--r--  1 a  wheel  0 12 18 16:18 c.js

例子:参数替换

有的时候,我们需要用到原始的参数,可以通过参数-i-I实现。参数说明如下

  -I R                         same as --replace=R (R must be specified)
  -i,--replace=[R]             Replace R in initial arguments with names
                               read from standard input. If R is
                               unspecified, assume {}

例子如下,将所有的.js结尾的文件,都加上.backup后缀。-I '{}'表示将后面命令行的{}替换成前面解析出来的参数。

ls *.js | xargs -t -I '{}' mv {} {}.backup

展开后的命令如下:

mv a.js a.js.backup
mv b.js b.js.backup
mv c.js c.js.backup

例子:参数分组

命令行对参数最大长度有限制,xargs通过-nx对参数进行分组来解决这个问题。

首先,创建4个文件用来做实验。

touch a.js b.js c.js d.js

然后运行如下命令:

ls *.js | xargs -t -n2 ls -al

输出如下,-n2表示,将参数以2个为一组,传给后面的命令。

ls -al a.js b.js 
-rw-r--r-- 1 root root 0 Dec 18 16:52 a.js
-rw-r--r-- 1 root root 0 Dec 18 16:52 b.js
ls -al c.js d.js 
-rw-r--r-- 1 root root 0 Dec 18 16:52 c.js
-rw-r--r-- 1 root root 0 Dec 18 16:52 d.js

例子:特殊文件名

有的时候,文件名可能存在特殊字符,比如下面的文件名中存在空格。

touch 'hello 01.css' 'hello 02.css'

运行之前的命令会报错,因为xargs是以空格/换行作为分隔符,于是就会出现预期之外的行为。

# 命令
find . -name '*.css' | xargs -t ls -al

#输出
ls -al ./hello 01.css ./hello 02.css # 展开后的命令
ls: cannot access ./hello: No such file or directory
ls: cannot access 01.css: No such file or directory
ls: cannot access ./hello: No such file or directory
ls: cannot access 02.css: No such file or directory

xargs是这样解决这个问题的。

  1. -print0:告诉find命令,在输出文件名之后,跟上NULL字符,而不是换行符;
  2. -0:告诉xargs,以NULL作为参数分隔符;
find . -name '*.css' -print0 | xargs -0 -t ls -al

例子:日志备份

将7天前的日志备份到特定目录

find . -mtime +7 | xargs -I '{}' mv {} /tmp/otc-svr-logs/

相关链接

https://craftsmanbai.gitbooks...

http://wiki.jikexueyuan.com/p...

5.5k 声望
1.3k 粉丝
0 条评论
推荐阅读
5分钟入门MP4文件格式
本文主要内容包括,什么是MP4、MP4文件的基本结构、Box的基本结构、常见且重要的box介绍、普通MP4与fMP4的区别、如何通过代码解析MP4文件 等。

程序猿小卡9阅读 5.3k

ESlint + Stylelint + VSCode自动格式化代码(2023)
安装插件 ESLint,然后 File -> Preference-> Settings(如果装了中文插件包应该是 文件 -> 选项 -> 设置),搜索 eslint,点击 Edit in setting.json

谭光志34阅读 20.7k评论 9

涨姿势了,有意思的气泡 Loading 效果
今日,群友提问,如何实现这么一个 Loading 效果:这个确实有点意思,但是这是 CSS 能够完成的?没错,这个效果中的核心气泡效果,其实借助 CSS 中的滤镜,能够比较轻松的实现,就是所需的元素可能多点。参考我们...

chokcoco22阅读 2.2k评论 3

你可能不需要JS!CSS实现一个计时器
CSS现在可不仅仅只是改一个颜色这么简单,还可以做很多交互,比如做一个功能齐全的计时器?样式上并不复杂,主要是几个交互的地方数字时钟的变化开始、暂停操作重置操作如何仅使用 CSS 来实现这样的功能呢?一起...

XboxYan23阅读 1.7k评论 1

封面图
在前端使用 JS 进行分类汇总
最近遇到一些同学在问 JS 中进行数据统计的问题。虽然数据统计一般会在数据库中进行,但是后端遇到需要使用程序来进行统计的情况也非常多。.NET 就为了对内存数据和数据库数据进行统一地数据处理,发明了 LINQ (L...

边城17阅读 2k

封面图
【代码鉴赏】简单优雅的JavaScript代码片段(一):异步控制
Promise.race不满足需求,因为如果有一个Promise率先reject,结果Promise也会立即reject;Promise.all也不满足需求,因为它会等待所有Promise,并且要求所有Promise都成功resolve。

csRyan26阅读 3.3k评论 1

「彻底弄懂」this全面解析
当一个函数被调用时,会创建一个活动记录(有时候也称为执行上下文)。这个记录会包含函数在 哪里被调用(调用栈)、函数的调用方法、传入的参数等信息。this就是记录的其中一个属性,会在 函数执行的过程中用到...

wuwhs17阅读 2.4k

封面图
5.5k 声望
1.3k 粉丝
宣传栏