我想找到传递给脚本的所有参数的长度。
如果我这样做:echo ${#1}
我看到了我的第一个参数的长度,如果我这样做:echo $*
我看到我的所有参数都用空格分隔。那么,为什么不能这样做:echo ${#*}
?相反,这向我展示了传递的参数数量,就好像它是echo $#
。
有没有办法在不将$ *的值写入新变量($allargs=$*
)的情况下回显总长度,然后检查新变量的长度(echo ${#allargs}
)?
答案 0 :(得分:1)
总结参数的长度:
#!/bin/bash
declare -i length # set integer attribute
for i in "${@}"; do length+=${#i}; done
echo $length
答案 1 :(得分:1)
嗯,是的,最简单的方法是:
$ IFS=''; a=$*; echo "${#a}"
是的,没有办法避免变量($a
),因为需要变量(参数)才能执行“参数扩展”(${#…}
)。
在上面,测量$@
中字符串的长度(在bash中的UNICODE代码点)。
使用LC_ALL = C来计算字节数。
如果你需要在每个字符串之间放置一个“空格”(假设IFS的第一个字符是一个空格,默认情况下是这样):
$ a=$*; echo "${#a}"
或者,要明确:
$ IFS=' '; a=$*; echo "${#a}"
当然,这会改变$IFS
的价值。有两种方法可以避免这种情况:
子shell
$ ( IFS=' '; a=$*; echo "${#a}" )
延迟与eval:
$ IFS=' ' eval 'a=$*'; echo "${#a}"
用于字节计数:
$ ( LC_ALL=C; IFS=' '; a=$*; echo "${#a}" )
$ LC_ALL=C IFS=' ' eval 'a=$*'; echo "${#a}"
是的,是的,在这种情况下,eval是安全的。
不,算术技巧不会使答案变得简单:
$ set -- one two t33; a=$*; echo "$((${#a}-$#+1))"
9
空"$@"
失败:
$ set -- ; a=$*; echo "$((${#a}-$#+1))"
1