目标
在ZSH脚本中,对于给定的args,我希望获得第一个字符串和其余字符串。
例如,当脚本名为test时
sh test hello应该提取h和ello。
ZSH手册
a4.pdf
说:
也可以对非数组值执行subscripts,在这种情况下,下标指定要提取的子字符串。例如,如果FOO设置为“foobar”,则“echo$FOO2,5”打印“ooba”。
Q1
所以,我在一个名为test的文件中编写了一个shell脚本
echo $1
echo $1[1,1]航站楼:
$ sh test hello
hello
hello[1,1]结果失败了。密码怎么了?
Q2
而且,我也不知道如何从n到最后提取subString。也许我必须使用由regex拆分的数组吗?
编辑: Q3
这可能是另一个问题,所以如果启动新线程是正确的,我将这样做。
感谢@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我不知道如何比较字符串和字符串,但是对于给定的args hello
结果:
command not found: h密码怎么了?
EDIT2:
我发现的是对的
#! /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
fiEDIT3:
作为整体的结果,这就是我对这个问题所做的。
https://github.com/kenokabe/GitSnapShot
GitSnapShot是一个用于Git命令的ZSH薄包装器,以便于更简单的使用。
发布于 2013-08-12 00:31:48
您可以使用剪切命令:
echo $1 | cut -c1
echo $1 | cut -c2-使用$()将这些值赋值给变量:
ARG_FIRST=$(echo $1 | cut -c1)
ARG_REST=$(echo $1 | cut -c2-)
echo ARG_FIRST=$ARG_FIRST
echo ARG_REST=$ARG_REST您也可以将$()替换为backticks,但建议使用前者,而后者由于嵌套问题而有些不推荐使用。
发布于 2015-06-29 16:17:36
A1
就像其他人说的,你需要用花括号包起来。另外,使用命令解释器(#!.),将文件标记为可执行文件,并直接调用它。
#!/bin/zsh
echo $1
echo ${1[1,1]}A2
从参数(zsh调用变量参数)中提取子字符串的最简单方法是使用参数展开。使用方括号告诉zsh将标量(即字符串)参数视为数组。对于一个角色来说,这是有意义的。对于字符串的其余部分,可以使用更简单的${parameter:start:length}表示法。如果您省略了:length部分(就像我们在这里所做的那样),那么它将为您提供其余的标量。
文件test
#!/bin/zsh
echo ${1[1]}
echo ${1:1}航站楼:
$ ./test Hello
H
elloA3
正如其他人所说,测试需要(最好是双)方括号。另外,对于测试字符串是否是NULL使用-z,并测试它是否为NULL使用-n。您可以将字符串放在双括号([[ ... ]])中,但是最好用-n来说明您的意图。
if [[ -z "${ARG_FIRST}" ]]; then
...
fi还删除#!和/bin/zsh之间的空格。如果要检查是否相等,请使用==;如果要赋值,则使用=。
关于:EDIT2 2:
$(...)代替。elif或case来避免嵌套的if. 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使用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
fiRE:EDIT3 3
"$@"。解释。发布于 2013-08-13 02:18:29
因此,我在一个名为test的文件中编写了一个shell脚本。
$ sh test hello这不是一个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. 运行以下代码:./test-script hello提供:
./test-script.zsh hello
hello
llo
./test-script.zsh:5: no matches found: hello[3,5]而且,我也不知道如何从n到最后提取subString。也许我必须使用由regex拆分的数组吗?
使用[n,last]表示法,但用大括号包装。我们可以确定变量的长度,然后使用长度:
# Store the length of $1 in LENGTH.
LENGTH=${#1}
echo ${1[2,${LENGTH}]} # Display from `2` to `LENGTH`. 这将产生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.您可以使用剪切命令:
但这将是使用额外的行李- zsh很有能力自己完成所有这一切,而不产生多个子外壳的简化操作。
https://stackoverflow.com/questions/18178075
复制相似问题