用途
构造参数列表并运行命令。
语法
xargs [-p t x ] [-e [EOFString]] [-E EOFString] [-i [ReplaceString] ] [-I ReplaceString | -L Number | -n Number] [ -l [ Number]] [-s Size] [Command [Argument ... ]]
注: 不要在小写标志和参数之间放置空格。
描述
生成的命令行长度是 Command 和每个作为字符串对待的 Argument(包括每个字符串的空字节 终结符)的大小的总和(以字节为单位)。xargs 命令限制命令行的长度。 当构造的命令行运行时,组合的 Argument和环境列表 不能超出 ARG_MAX 字节。在这个约束下,如果 不指定 -n 或 -s 标志,缺省命令行长度 至少是由 LINE_MAX 指定的值。
标志
项目 | 描述 |
---|---|
-e[EOFString] | 废弃的标志。请使用 -E 标志。 将 EOFString 参数用作逻辑 EOF 字符串。如果不 指定 -e 或 -E 标志,那么假定下划线(_)为逻辑 EOF 字符串。如果 不指定 EOFString 参数,那么禁用逻辑 EOF 字符串 能力,且下划线按照字面含义使用。xargs 命令读取标准输入直到达到 EOF 或指定的字符串。 |
-E EOFString | 指定逻辑 EOF 字符串以替换缺省的下划线 (_)。xargs 命令读取标准输入直到达到 EOF 或指定的字符串。 |
-i [ReplaceString] | 废弃的标志。使用 -I(大写 i)标志。 如果没有指定 ReplaceString 参数,那么将使用字符串 {}。 注意:-I(大写 i)、 i、 -L(大写 l)、 l 和 -n 标志是相互排斥的。最后指定的标志生效。 |
-I ReplaceString | (大写 i)。插入标准输入的每一行作为 Command 参数的自变量,将它插入每个发生 ReplaceString 的 Argument 中。ReplaceString 不能在超过 5 个自变量中使用。 在每个标准输入行开始的空字符被忽略。 每个 Argument 能包含一个或多个 ReplaceString,但不能大于 255 字节。-I 标志同样打开-x 标志。 -I(大写 i)标志表示 -L1。因此,一次只能将一个标准输入行替换为参数。如果替换的字符串在命令参数中出现多次,那么相同的标准输入行都会替换为每次出现的替换字符串。 注意:-I(大写 i)、 i、 -L(大写 l)、 l 和 -n 标志是相互排斥的。最后指定的标志生效。 |
-l [Number] | (小写的 L)。废弃的标志。请使用 -L 标志。 如果没有指定 Number 参数,使用缺省值 1。-l 标志同样打开 -x 标志。 注意:-I(大写 i)、 i、 -L(大写 l)、 l 和 -n 标志是相互排斥的。最后指定的标志生效。 |
-L Number | 用从标准输入读取的指定行数的非空参数运行 Command 命令。如果保留少于指定的 Number,Command 参数 的最后调用可以有少数几个参数行。行以第一个换行字符结束,除非该行的最后一个字符是一个空格 或制表符。后续的空格表示延续至下一个非空行。 读取标准输入中的 Number 行,然后将其放在命令行的末尾。 注意:-I(大写 i)、 i、 -L(大写 l)、 l 和 -n 标志是相互排斥的。最后指定的标志生效。 |
-n Number | 运行 Command 参数,且使用尽可能多的标准输入自变量,直到 Number 参数指定的最大值。 读取标准输入中的 Number 自变量的最大值,然后将其放在命令行的末尾。 如果满足以下条件,那么 xargs 命令使用 更少的自变量:
|
-p | 询问是否运行 Command 参数。 它显示构造的命令行,后跟一个 ?...(问号和省略号)提示。输入肯定的、特定于语言环境的响应 以运行 Command 参数。 任何其他响应都会引起 xargs 命令 跳过那个特定的参数调用。每个调用都将询问您。-p 标志同样打开 -t 标志。 |
-s Size | 设置构造的 Command 行的最大 总大小。Size 参数必须是正整数。如果满足以下条件,那么使用更少的自变量:
|
-t | 启用跟踪方式,并在运行之前将构造的 Command 行回送到标准错误。 |
-x | 如果有任何 Command 行大于 -s Size 标志指定的字节数,停止运行 xargs 命令。如果指定 -I(大写 i)或 -l(小写 L)标志,那么打开 -x 标志。如果 没有指定 -i、-I(大写 i)、-l(小写 L)、-L 或 -n 标志,那么 Command 行的总长度必须 在 -s Size 标志指定的限制内。 |
退出状态
本命令返回以下退出值:
项目 | 描述 |
---|---|
0 | 所有 Command 参数的调用 都返回退出状态 0。 |
1-125 | 不能汇编满足指定需求的命令行,一个或多个 Command 参数的调用 返回一个非零的退出状态,或发生一些其他的错误。 |
126 | Command 已找到但不能被调用。 |
127 | 找不到 Command。 |
如果不能汇编满足指定需求的命令行,那么不能调用此命令,命令的调用被一个信号终止,或此命令的调用以退出状态 255 退出。xargs 命令将写一条诊断消息并 退出而不处理任何保留的输入。
示例
- 要对名称在文件中列出的文件使用命令,请输入:
如果 cfiles 文件包含下面的 文本:xargs lint -a <cfiles
xargs 命令就构造并运行 下面的命令:main.c readit.c gettoken.c putobj.c
如果 cfiles 文件包含的文件名比在单一 shell 命令行上能处理的文件名(最多 LINE_MAX)要多, xargs 命令会用后者运行 lint 命令。然后它使用余下的文件名构造并运 行另一个 lint 命令。 根据在 cfiles 文件中列出的名称,命令看起来可能类似于如下所示的内容:lint -a main.c readit.c gettoken.c putobj.c
该命令序列同用所有的文件名运行 lint 命令一次不完全一样。 lint 命令检查文件之间的交叉参考。然而,在这个示例中,它不能在 main.c 和 fltadd.c 文件之间,或任意两个在分开 的命令行上列出的文件之间进行检查。lint -a main.c readit.c gettoken.c . . . lint -a getisx.c getprp.c getpid.c . . . lint -a fltadd.c fltmult.c fltdiv.c . . .
由于这个原因,仅当所有的文件名都在一行上列出时,才可能运行命令。要将这个指定 到 xargs 命令,通过输入以下命令使用 -x 标志:
xargs -x lint -a <cfiles
如果在文件 cfiles 中的所有 文件名没有在一个命令行上列出,xargs 命令 显示一条错误消息。 - 要构造包含一定数量文件名的命令,请输入:
xargs -t -n 2 diff <<EOF
该命令序列构造并运行每个包含两个文件名的 diff 命令(-n 2):
starting chap1 concepts chap2 writing
chap3
EOF
-t 标志使 在运行 xargs 命令前显示每个命令,这样您可以看到正在发生的事件。 <<EOF 和 EOF 模式匹配字符定义 一个 here document,它将在结尾行之前输入的文本用作对 xargs 命令的标准输入。diff starting chap1 diff concepts chap2 diff writing chap3
- 要将文件名插入命令行的中间,请输入:
ls | xargs -t -I {} mv {} {}.old
该命令序列通过在每个名称结尾添加 .old 来重命名在当前目录里的所有文件。-I 标志告诉 xargs 命令插入有{} (花括号)出现的 ls 目录列表的每一行。 如果当前目录包含文件 chap1、chap2 和 chap3,这会构造下面的命令:mv chap1 chap1.old mv chap2 chap2.old mv chap3 chap3.old
- 要对个别选择的文件运行命令,请输入: 该命令序列允许选择文件以添加到 lib.a 库。-p 标志告诉 xargs 命令去 显示每个它构造的 ar 命令,并询问是否想 运行它。输入 y 来运行命令。如果不想 运行此命令按任意其他键。
会显示一些类似于下面的内容:
ar r lib.a chap1 ?... ar r lib.a chap2 ?... ar r lib.a chap3 ?...
- 要构造包含特定数量自变量的 命令并将那些自变量插入一个命令行的中间,请输入:
如果当前目录 包含从 chap1 到 chap10 的文件,构造的输出将会是下列内容:ls | xargs -n6 | xargs -I{} echo {} - some files in the directory
chap1 chap2 chap3 chap4 chap5 chap6 - some files in the directory chap7 chap8 chap9 chap10 - some file in the directory
文件
项目 | 描述 |
---|---|
/usr/bin/xargs | 包含 xargs 命令。 |