在bash中将文件转换为2d数组

问题描述 投票:2回答:2

我正在开发一个项目,我将一些数据保存到文件(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
bash shell solaris
2个回答
3
投票

在你的评论之后,看起来你需要一个简单的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.txtdone循环的末尾指定。


3
投票

您可以设置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

© www.soinside.com 2019 - 2024. All rights reserved.