2

我非常彻底地搜索了该网站,但无法找到合适的答案——很可能我没有问正确的问题。

我有一个文本文件,其中包含多达数千行坐标,其格式如下例所示:

[1]
-75.4532 75.8273 
-115.00 64.5 
-90.00 74.3333 
-100.00 72.4167 
-110.00 69.00 
-120.8 56.284 
[2]
-70.00 73.75 
-100.00 69.3333 
-110.00 65.1533 
-90.00 71.5833 
-80.00 73.00 
[3]
-100.00 67.5 
-67.7133 72.6611 
-80.00 71.5 
-90.00 70.00 
-110.00 63.8667 
-115.8 60.836 

我想要实现的是将文件拆分为括号中数字的数组。这样我就可以将括号中的数字用作数组索引,并将以下几行用作相应的值。

下一步将遍历数组,将每个元素馈送到另一个程序。如果有更优雅的方法,我愿意听。

一切顺利!

4

2 回答 2

2

您可以使用 sed 将文件按摩到 bash 数组定义中:

declare -a "$(sed 's/\[/" &/g; s/\]/&="/g' file | sed '1s/^"/arr=(/; $s/$/")/')"
echo "${arr[2]}"
echo
echo ${arr[2]}
-70.00 73.75 
-100.00 69.3333 
-110.00 65.1533 
-90.00 71.5833 
-80.00 73.00 

-70.00 73.75 -100.00 69.3333 -110.00 65.1533 -90.00 71.5833 -80.00 73.00

带引号和不带引号的打印以显示差异

于 2013-11-07T15:54:29.067 回答
2

使用read -d(设置记录分隔符)和IFS(设置字段分隔符)的组合:

# read content from file
content="$(<input_filename)"

# append record separator to avoid dropping the last record
content="$content["

# read into array
arr=()
while IFS=']' read -d '[' sub value; do
    arr[$sub]=$value
done <<<"$content"

结果数组将有一个空的第一个元素,因为它是从零开始的。这会使遍历它变得更加棘手。您可以显式删除第一个元素以使循环更容易:

unset arr[0]

现在您可以遍历元素:

for value in "${arr[@]}"; do
    program < "$value"
done

或者如果您还需要基于 1 的索引:

for ((i=1; i<=${#arr[@]}; i++)); do
    program "$i" "$value"
done

希望有帮助!

于 2013-11-07T16:02:19.133 回答