将文本文件格式化为列

时间:2015-05-20 10:04:05

标签: arrays bash shell text-files

我有一个包含数据的文本文件,它像桌子一样设置,但用逗号分隔,例如:

姓名,年龄,FavColor,地址

鲍勃,18岁,蓝色,1史密斯街

朱莉,17岁,黄色,约翰街4号

首先,我尝试使用for循环,并将每个'column'及其所有值放入一个单独的数组中。

例如/'nameArray'将包含bob,julie。

以下是我的实际脚本中的代码,有12列,因此c不应该大于12。

declare -A Array

for((c = 1; c <= 12; c++))
{
    for((i = 1; i <= $total_lines; i++))
    {
        record=$(cat $FILE | awk -F "," 'NR=='$i'{print $'$c';exit}'| tr -d ,)
        Array[$c,$i]=$record

    }
}

从这里我然后使用'printf'函数格式化每个数组并将它们打印为列。这个问题是我有超过3个数组,在我的实际代码中,它们都在同一个'printf'行。这是我不喜欢的,我知道这是一种愚蠢的方式。

for ((i = 1; i <= $total_lines; i++))
{
    printf "%0s %-10s %-10s...etc \n" "${Array[1,$i]}" "${Array[2,$i]}" "${Array[3,$i]}" ...etc
}

然而,这确实给了我想要的输出,见下图:

enter image description here

我想弄清楚如何以另一种方式做到这一点,不需要大量的打印声明。我第一次调用for循环时出现'awk'错误。

任何建议都会受到赞赏,我已经查看了多个主题和帖子,试图找到合适的解决方案,但没有找到有用的东西。

1 个答案:

答案 0 :(得分:6)

尝试像

这样的column命令

column -t -s','

这是我能很快得到的。有关详细信息,请参见手册页。