从管道分隔文件中检索字段行

从管道分隔文件中检索字段行

我需要从管道分隔文件中获取前 9 个单词,然后获取接下来的 9 个单词。

 cat a.txt
a|b|c|d|e|f|g|h|i|j|k|l|m|n|o|p|q|r|s|t|u|v|w|x|y|z|

猫新.ksh

#! /bin/ksh
a=`awk -F "|" ' { print NF-1 } ' a.txt`
echo $a

预期输出:

grep -i "a|b|c|d|e|f|g|h|i" b.txt >> c.txt
grep -i "j|k|l|m|n|o|p|q|r" b.txt >> c.txt
grep -i "s|t|u|v|w|x|y|z" b.txt >> c.txt

答案1

与 sed

sed -E 's/(([^|]+\|){1,9})/\1\n/g' a.txt

或 perl

perl -F'\|' -lanE 'while (@F) {say join("|", splice @F, 0, 9), "|"}' a.txt

答案2

怎么样

$ tr '|' $'\n' < file | paste -sd'||||||||\n'
a|b|c|d|e|f|g|h|i
j|k|l|m|n|o|p|q|r
s|t|u|v|w|x|y|z|

相关内容