我需要从管道分隔文件中获取前 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|