我已经查看了如何在 SO 上使用 shell 计算字符串中的字数的问题,它解释了如何计算变量内的字数。
但这仅在我的变量中计算一个单词,所以我不知道如何修复它。
我有以下变量:
vmfarm1=(host1.com host2.com host3.com host4.com )
maximus=(host11.com host 12.com host 13.com)
firefly=(host5.com)
我需要找到一种方法将所有主机名计入变量内的一个数字中。
在此之后,被计算在内的数字必须用作该行中的变量。
我努力了:
echo "$input" | wc -w
printf ' \n|/4.vmfarm1 ' >> textfile.txt
我必须4
自己将以上内容写入数字,并且需要自动完成,这就是我需要变量的原因。
要在具有数组支持的各种 shell 中打印数组变量中的元素数:
csh
/tcsh
/zsh
/rc
/es
/akanga
:echo $#array
ksh
¹/bash
¹/zsh
:echo "${#array[@]}"
fish
:count $array
yash
:echo "${array[#]}"
"$@"
):echo "$#"
现在对于数组变量的所有元素中以空格分隔的单词的数量,这就是您可能想要使用的地方
wc -w
,但是您需要向它提供由至少一个空格分隔的所有元素的内容,例如:或者,您可以将元素拆分为更多以空格分隔的单词,并将它们计入 shell 本身。
csh
/tcsh
(在 SPC/TAB/NL 上拆分)ksh
//bash
(拆分yash
,$IFS
默认为SPC/TAB/NL)zsh
($IFS
拆分,默认为SPC/TAB/NL/NUL)rc
/es
($ifs
分裂):fish
(计算所有非空白(根据 PCRE)字符序列):Bourne/POSIX(
$IFS
拆分):¹ 请注意,鉴于
ksh
/bash
数组是稀疏的,并且在每个其他 shell 中索引从 0 而不是 1 开始,该数字通常与数组中的最大索引不同给定一个数组
arr
,它的长度(元素数)由 给出${#arr[@]}
。将此与您的
vmfarm1
数组一起使用:vmfarm1, maximus
firefly
不仅仅是变量,它们是数组。使用正确的语法:
${#vmfarm1[@]}
是数组中的条目数。在 Bash 和 ksh 中,将数组作为普通字符串变量进行扩展,会给出数组的第一个元素。即,
$somearray
与 相同${somearray[0]}
。(*)所以,
打印
foo
and1
, 因为foo
只有一个词。如果你有somearray=("foo bar doo" "acdc abba")
,那么wc
将显示三个单词。您需要使用
"${somearray[@]}"
将数组的所有元素扩展为不同的 shell 词(参数),或者"${somearray[*]}"
将它们扩展为单个 shell 词,并用空格(**)连接在任何情况下,请注意数组中元素的数量和单词的数量(在
wc -w
人类语言的意义上)是不一样的,见下文。用于"${#somearray[@]}"
获取数组中元素的数量。(*) 现在忽略稀疏和关联数组。
(**) 假设默认
IFS
.这可能不聪明,但我认为您可以获得阵列中的主机数量。
谢谢