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

标签 linux bash unix 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

代码:

cat text_data | awk 'BEGIN{FS=" "};{print NF}'

输出:

15
15
8
8
15
15
15
1
15

最佳答案

反过来做:只打印至少有 X 列的那些:

awk -v cols=5 'NF>=cols' file

也就是说,将变量 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

关于linux - 计算文本文件中的列数后删除行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33938781/

相关文章:

c - fread()、solaris 到 unix 的可移植性和未初始化值的使用

Bash vi 模式 - 绑定(bind) "C-c"以退出插入模式

regex - 使用 sed 查找模式包围的文本

html - 如何使用awk根据其他字段求和字段

linux - 使用正则表达式对文件运行 awk

linux - Perl 加密 STDIN 密码

linux - 在 Bash 循环中增加一个零填充的 int

linux - 进程替换 >(cmd) 输出不正确

我可以在 C 中的 2 个子进程之间使用相同的管道吗?

Android Studio 无法更新,Ubuntu 16.04