6 zsh
在ZSH脚本中,对于给定的args,我想获得第一个字符串和其余字符串.
例如,当脚本被命名时 test
sh test hello
Run Code Online (Sandbox Code Playgroud)
应该提取h和ello.
http://zsh.sourceforge.net/Doc/zsh_a4.pdf
说:
也可以对非数组值执行订阅,在这种情况下,下标指定要提取的子字符串.例如,如果FOO设置为'foobar',则'echo $ FOO [2,5]'打印'ooba'.
所以,我在一个名为的文件中编写了一个shell脚本 test
echo $1
echo $1[1,1]
Run Code Online (Sandbox Code Playgroud)
终奌站:
$ sh test hello
hello
hello[1,1]
Run Code Online (Sandbox Code Playgroud)
结果失败了.代码有什么问题?
另外我不知道如何从n到最后一个提取subString.也许我必须使用正则表达式拆分阵列?
这可能是另一个问题,所以如果启动新线程是正确的,我会这样做.
感谢@skishore这是进一步的代码
#! /bin/zsh
echo $1
ARG_FIRST=`echo $1 | cut -c1`
ARG_REST=`echo $1 | cut -c2-`
echo ARG_FIRST=$ARG_FIRST
echo ARG_REST=$ARG_REST
if $ARG_FIRST = ""; then
echo nullArgs
else
if $ARG_FIRST = "@"; then
echo @Args
else
echo regularArgs
fi
fi
Run Code Online (Sandbox Code Playgroud)
我不确定如何将字符串贵重物品与字符串进行比较,但对于给定的args hello
结果:
command not found: h
Run Code Online (Sandbox Code Playgroud)
代码有什么问题?
我发现的正确
#! /bin/zsh
echo $1
ARG_FIRST=`echo $1 | cut -c1`
ARG_REST=`echo $1 | cut -c2-`
echo ARG_FIRST=$ARG_FIRST
echo ARG_REST=$ARG_REST
if [ $ARG_FIRST ]; then
if [ $ARG_FIRST = "@" ]; then
echo @Args
else
echo regularArgs
fi
else
echo nullArgs
fi
Run Code Online (Sandbox Code Playgroud)
作为整体的结果,这就是我对这个问题所做的.
GitSnapShot是GIT命令的ZSH瘦包装器,可以更简单,更简单地使用
正如其他人所说,您需要将其包裹在花括号中。此外,使用命令解释器 ( #!...),将文件标记为可执行文件,然后直接调用它。
#!/bin/zsh
echo $1
echo ${1[1,1]}
Run Code Online (Sandbox Code Playgroud)
从参数中提取子字符串的最简单方法(zsh 调用变量参数)是使用参数扩展。使用方括号告诉 zsh 将标量(即字符串)参数视为数组。对于单个字符,这是有道理的。对于字符串的其余部分,您可以使用更简单的${parameter:start:length}表示法。如果您省略该:length部分(我们将在此处省略),那么它将为您提供其余的标量。
文件test:
#!/bin/zsh
echo ${1[1]}
echo ${1:1}
Run Code Online (Sandbox Code Playgroud)
终端:
$ ./test Hello
H
ello
Run Code Online (Sandbox Code Playgroud)
正如其他人所说,您需要(最好是双)方括号进行测试。此外,要测试字符串是否为NULL使用-z,并测试它是否为NULL使用-n。您可以将字符串放在双括号 ( [[ ... ]]) 中,但最好使用-n.
if [[ -z "${ARG_FIRST}" ]]; then
...
fi
Run Code Online (Sandbox Code Playgroud)
同时删除之间的空间#!和/bin/zsh。如果您要检查相等性,请使用==; 如果要赋值,请使用=.
$(...)来代替。eliforcase避免嵌套ifs。case在您的示例中会更容易阅读,但elif对于您的实际代码可能会更好。使用case:
#!/bin/zsh
typeset ARG_FIRST="${1[1]}"
typeset ARG_REST="${1:1}"
echo $1
echo 'ARG_FIRST='"${ARG_FIRST}"
echo 'ARG_REST='"${ARG_REST}"
case "${ARG_FIRST}" in
('') echo 'nullArgs' ;;
('@') echo '@Args' ;;
(*)
# Recommended formatting example with more than 1 sloc
echo 'regularArgs'
;;
esac
Run Code Online (Sandbox Code Playgroud)
使用elif:
#!/bin/zsh
typeset ARG_FIRST="${1[1]}"
typeset ARG_REST="${1:1}"
echo $1
echo 'ARG_FIRST='"${ARG_FIRST}"
echo 'ARG_REST='"${ARG_REST}"
if [[ -z "${ARG_FIRST}" ]]; then
echo nullArgs
elif [[ '@' == "${ARG_FIRST}" ]]; then
echo @Args
else
echo regularArgs
fi
Run Code Online (Sandbox Code Playgroud)
"$@"除非您真的知道自己在做什么,否则请使用。解释。您可以使用cut命令:
echo $1 | cut -c1
echo $1 | cut -c2-
Run Code Online (Sandbox Code Playgroud)
使用$()这些值赋给变量:
ARG_FIRST=$(echo $1 | cut -c1)
ARG_REST=$(echo $1 | cut -c2-)
echo ARG_FIRST=$ARG_FIRST
echo ARG_REST=$ARG_REST
Run Code Online (Sandbox Code Playgroud)
您也可以$()用反引号替换,但建议使用前者,后者因嵌套问题而略微弃用.
所以,我在一个名为test的文件中编写了一个shell脚本
$ sh test hello
Run Code Online (Sandbox Code Playgroud)
这不是一个zsh脚本:你用它来调用它sh,这几乎可以肯定bash.如果你有shebang(#!/bin/zsh),你可以使它成为可执行文件(chmod +x <script>)并运行它:./script.或者,您可以运行它zsh <script>.
结果失败了.代码有什么问题?
你可以用大括号括起来:
echo ${1} # This'll work with or without the braces.
echo ${1[3,5]} # This works in the braces.
echo $1[3,5] # This doesn't work.
Run Code Online (Sandbox Code Playgroud)
运行这个:./test-script hello给:
./test-script.zsh hello
hello
llo
./test-script.zsh:5: no matches found: hello[3,5]
Run Code Online (Sandbox Code Playgroud)
另外我不知道如何从n到最后一个提取subString.也许我必须使用正则表达式拆分阵列?
使用[n,last]符号,但用大括号括起来.我们可以确定变量的长度,然后使用长度:
# Store the length of $1 in LENGTH.
LENGTH=${#1}
echo ${1[2,${LENGTH}]} # Display from `2` to `LENGTH`.
Run Code Online (Sandbox Code Playgroud)
这将产生ello(从第二个字符打印到最后一个字符hello).
剧本:
#!/usr/local/bin/zsh
echo ${1} # Print the input
echo ${1[3,5]} # Print from 3rd->5th characters of input
LENGTH=${#1}
echo ${1[2,${LENGTH}]} # Print from 2nd -> last characters of input.
Run Code Online (Sandbox Code Playgroud)
您可以使用cut命令:
但这将是使用额外的行李 - zsh完全有能力完成所有这一切,而不会产生多个子壳,以简化操作.
| 归档时间: |
|
| 查看次数: |
10948 次 |
| 最近记录: |