我有一个包含以下内容的文件/字符串:
[1-9]
[11-12]
[10-15]
然后我想将其扩展为:
1 2 3 4 5 6 7 8 9
11 12
10 11 12 13 14 15
我知道如何以很长的方式做到这一点(首先捕获两个数字,然后使用 for 循环扩展它们)。
我想知道是否有更快/更智能的方法来实现同样的目标。
我有一个包含以下内容的文件/字符串:
[1-9]
[11-12]
[10-15]
然后我想将其扩展为:
1 2 3 4 5 6 7 8 9
11 12
10 11 12 13 14 15
我知道如何以很长的方式做到这一点(首先捕获两个数字,然后使用 for 循环扩展它们)。
我想知道是否有更快/更智能的方法来实现同样的目标。
一种方法:(纯 bash 解决方案)
while IFS=- read l1 l2
do
eval echo ${l1/[/{}".."${l2/]/}}
done < file
有几种解决方案。
解决方案1:
sed 's/^/echo /; s/[[]/{/; s/]/}/; s/-/../' | bash
例子:
$ cat 1.txt | sed 's/^/echo /; s/[[]/{/; s/]/}/; s/-/../' | bash
1 2 3 4 5 6 7 8 9
11 12
10 11 12 13 14 15
解决方案2:
tr '[]-' ' ' | sed "s/^/seq -s' '/" | bash
例子:
$ cat 1.txt | tr '[]-' ' ' | sed "s/^/seq -s' '/" | bash
1 2 3 4 5 6 7 8 9
11 12
10 11 12 13 14 15
如果您确信您的输入都与该模式匹配:
while read a; do
seq -s' ' $(echo "$a" | tr '[]-' ' ')
done
根据需要添加错误检查。
这是一个单行:
cat lines | sed -E -e 's/\[|]//g' -e 's/-/ /g' | xargs -n 2 seq -s ' ' -t '\n'
如:
$ cat <<EOF | sed -E -e 's/\[|]//g' -e 's/-/ /g' | xargs -n 2 seq -s ' ' -t '\n'
> [1-9]
> [11-12]
> [10-15]
> EOF
1 2 3 4 5 6 7 8 9
11 12
10 11 12 13 14 15