在计算文本文件中的列数后删除行

Aar*_*rry 6 unix linux bash awk

我需要在计算其中的列数后动态删除一行.例如,如果行中的列数小于X,则删除整行.我有一个包含100多行的文本文件.

这是我到目前为止所拥有的,它计算文本文件每行中的总列数...

文字样本:

KGAI 2 2 40 50 50 98 75 10 35 40 15 25 15 55
KGED 3 3 15 25 20 60 60 20 50 25 15 25 20 40
KGFL 1 10 3 4 3 85 25
KGHG        15 20 40 20 20 20 20
KGKJ 20 80 25 20 25 97 50 20 60 45 30 30 25 30
KGNR 2 30 4 5 5 25 90 10 35 15 15 15 10 20
KGON 1 1 20 10 5 85 65 5 20 30 15 10 15 25
KGTB
KHEF 2 2 20 30 50 98 60 10 30 25 10 15 10 45
Run Code Online (Sandbox Code Playgroud)

码:

cat text_data | awk 'BEGIN{FS=" "};{print NF}'
Run Code Online (Sandbox Code Playgroud)

输出:

15
15
8
8
15
15
15
1
15
Run Code Online (Sandbox Code Playgroud)

fed*_*qui 7

反之亦然:只打印那些至少有X列的那些:

awk -v cols=5 'NF>=cols' file
Run Code Online (Sandbox Code Playgroud)

也就是说,将变量设置为cols您希望该行具有的最小cols数量的值.只要是真的,就会打印出该行.

在这种情况下,它返回:

KGAI 2 2 40 50 50 98 75 10 35 40 15 25 15 55
KGED 3 3 15 25 20 60 60 20 50 25 15 25 20 40
KGFL 1 10 3 4 3 85 25
KGHG        15 20 40 20 20 20 20
KGKJ 20 80 25 20 25 97 50 20 60 45 30 30 25 30
KGNR 2 30 4 5 5 25 90 10 35 15 15 15 10 20
KGON 1 1 20 10 5 85 65 5 20 30 15 10 15 25
KHEF 2 2 20 30 50 98 60 10 30 25 10 15 10 45
Run Code Online (Sandbox Code Playgroud)