fed*_*qui 6 arrays bash parameter-expansion
假设我将一些数据读入 Bash 数组:
$ IFS=" " read -a arr <<< "hello/how are/you iam/fine/yeah"
Run Code Online (Sandbox Code Playgroud)
现在,我想打印/数组中每个元素的第一个切片字段。
我所做的是循环遍历元素并使用 shell 参数扩展从第一个元素中删除所有内容/:
$ for w in "${arr[@]}"; do echo "${w%%/*}"; done
hello
are
iam
Run Code Online (Sandbox Code Playgroud)
但是,sinceprintf允许我们在单个表达式中打印数组的全部内容:
$ printf "%s\n" "${arr[@]}"
hello/how
are/you
iam/fine
Run Code Online (Sandbox Code Playgroud)
...我想知道是否有一种方法可以${w%%/*}在使用时使用 shell 参数扩展printf,而不是循环遍历所有元素并对每个元素执行此操作。
哦,我刚刚找到了方法:正常使用参数扩展即可,只是反对${arr[@]}而不是${arr}!
$ IFS=" " read -a arr <<< "hello/how are/you iam/fine/yeah"
$ printf "%s\n" "${arr[@]%%/*}"
hello
are
iam
Run Code Online (Sandbox Code Playgroud)
格雷格的维基在这里提供了帮助:
BASH 数组非常灵活,因为它们与其他 shell 扩展很好地集成。可以在标量或单个数组元素上执行的任何参数扩展都可以同样应用于整个数组或位置参数集,以便立即扩展所有成员,可能会在每个元素上映射附加操作。
Run Code Online (Sandbox Code Playgroud)$ a=(alpha beta gamma) # assign to our base array via compound assignment $ echo "${a[@]#a}" # chop 'a' from the beginning of every member lpha beta gamma $ echo "${a[@]%a}" # from the end alph bet gamm $ echo "${a[@]//a/f}" # substitution flphf betf gfmmf