amp*_*ine 67
别名就像命令一样,它们的所有参数都作为参数传递给它们别名的程序。例如,如果您将别名设置ls
为ls -la
,则键入ls foo bar
将真正ls -la foo bar
在命令行上执行。
如果您想实际控制参数的解释方式,则可以编写如下函数:
my_program_wrapper() {
local first_arg="$1" \
second_arg="$2"
shift 2 # get rid of the first two arguments
# ...
/path/to/my_program "$@"
}
Run Code Online (Sandbox Code Playgroud)
Tom*_*ale 67
别名解决方案
如果你真的反对使用函数本身,你可以使用:
$ alias wrap_args='f(){ echo before "$@" after; unset -f f; }; f'
$ wrap_args x y z
before x y z after
Run Code Online (Sandbox Code Playgroud)
如果您只想要第一个参数$@
,$1
则可以替换为。
解释
这将创建一个临时函数f
,该函数被传递参数。
别名参数仅在最后传递。请注意,f
在别名的最后调用。
在unset -f
执行别名时删除函数定义,因此它之后不会挂起。
roz*_*acz 23
添加到目前的答案中,要意识到别名如何工作的一件重要事情是,您在别名命令之后键入的所有参数都将在最后按字面意思使用。所以没有办法为两个命令(管道或非管道)使用别名,其中第一个应该解释参数。为了清楚起见,这里有一个无法按预期工作的示例:
alias lsswp="ls -l | grep swp"
Run Code Online (Sandbox Code Playgroud)
(受此问题启发的示例)这将始终使用ls -l
在当前目录中执行的输出并对其执行 grep - 所以使用
lsswp /tmp/
将等价于ls -l | grep swp /tmp/
和不 ls -l /tmp/ | grep swp
。
对于应该在中间某处使用参数的所有目的,需要使用 afunction
而不是alias
。
War*_*ung 17
实际上,您无需执行任何操作;别名会自动执行此操作。例如:
$ alias less="less -eirqM"
$ less foo.txt
Run Code Online (Sandbox Code Playgroud)
您将看到 foo.txt 的第一页,并将less
在 EOF (-e) 处退出,搜索将不区分大小写 (-i) 等。
我正在回答 csh:
是的,您可以在别名中使用参数,并且与上面所说的不同,您可以在别名定义中的任何位置引用它们,而不仅仅是在最后。
tar-gz -ing 的示例:
$ alias tgz "tar cvf - \!:1 | gzip -9 > \!:2.tar.gz"
Run Code Online (Sandbox Code Playgroud)
,其中!:1
和!:2
是调用别名时将提供的参数。
使用示例:
$ ls
clrcf.dat user_comment_2016.06.03_12:51:50.txt user_comment_2016.06.03_12:54:48.txt
TEST-wADM.tec user_comment_2016.06.03_12:52:04.txt user_comment_2016.06.03_12:55:13.txt
$ tgz user* out
a user_comment_2016.06.03_12:51:50.txt 1K
a user_comment_2016.06.03_12:52:04.txt 1K
a user_comment_2016.06.03_12:54:48.txt 1K
a user_comment_2016.06.03_12:55:13.txt 1K
$ ls out*
out.tar.gz
Run Code Online (Sandbox Code Playgroud)
这实际上意味着您使用了在 tar 命令的任意位置插入的两个参数,使其成为别名tgz