假设我有一个文本文件“demo.txt”,其中有一个如下表:
1 2 3
4 5 6
7 8 9
现在,我想使用 bash 中的“readarray”命令单独读取每一行,所以我写:
readarray myarray < demo.txt
问题是它不起作用。如果我尝试使用以下方式打印“myarray”:
echo $myarray
I get:
1 2 3
另外,如果我写:
echo ${myarray[1]}
I get:
4 5 6
代替:
2
正如我所料。这是为什么?如何分别访问每一行并在该行中访问每个成员?
这是预期的行为。readarray
将创建一个数组,其中数组的每个元素都是输入中的一行。
如果你想查看整个数组,你需要使用
echo "${myarray[@]}"
as echo "$myarray
只会输出myarray[0]
, and ${myarray[1]}
是数据的第二行。
您正在寻找的是一个二维数组。参见例如this https://stackoverflow.com/questions/16487258/how-to-declare-2d-array-in-bash.
如果你想要一个包含第一行内容的数组,你可以这样做:
$ read -a arr < demo.txt
$ echo ${arr[0]}
1
$ echo ${arr[1]}
2
$ echo ${arr[2]}
3
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)