我正在开发一个项目,我将一些数据保存到文件(data.txt)。
10010101010;99;18767654536;252525
89878337326;44;18764329087;242424
现在的下一步是将数据读入2D数组,其中row [0]是第一行,row [1]是第二行。我正在努力实现这一目标。此外,我希望能够访问每一行的各个元素
我目前有这个代码,但它只打印第一行,我无法访问元素
read -a rows < data.txt
for row in "${rows[@]}";do
row_array=(${row})
first=${row_array[0]}
sec=${row_array[1]}
echo ${first}
echo ${sec}
done
在你的评论之后,看起来你需要一个简单的while read
循环:
while IFS=';' read -r id rest; do
if [[ "$id" == "10010101010" ]]; then
echo "Matching line : $id $rest"
fi
done < data.txt
在此代码中,IFS=';'
指定使用;
字符作为命令read
的内部字段分隔符,这将使其将每个行解析为四个不同的单词。
read -r
后面的名称对应于用于存储每个单词的变量,如果单词多于变量,则最后一个单词包含行的其余部分。
read -r id rest
将第一列存储在$id
变量中,其余的单词存储到$rest
中,而read -r first second third fourth
将每个单词存储在自己的变量中。
read
命令的输入在while
关闭循环后附加< data.txt
的done
循环的末尾指定。
您可以设置internal field separator (IFS)变量。内部字段分隔符(缩写为IFS)是指一个变量,它定义用于将模式分离为某些操作的标记的字符。它将解析由;
分隔的一行项目,将其推入数组DATA
。
#!/bin/bash
while IFS=\; read -ra DATA; do
for i in "${DATA[@]}"; do
echo -e "$i"
done
echo
done
示例脚本将生成以下输出:
10010101010
99
18767654536
252525
89878337326
44
18764329087
242424