如何在Linux中删除多列数据 (linux删除多列)

在Linux中,删除多列数据是很常见的任务,但是对于新手可能会感到有些难度。本文将介绍如何通过几种方法在Linux中删除多列数据。

方法一:使用cut命令

cut命令是Linux中一个强大的工具,可以将文件中的每一行按照指定的分隔符分割为多个字段,并将指定的字段提取出来输出到屏幕或者文件中。

例如,下面是一个含有多列数据的文件example.txt:

“`

1 2 3

4 5 6

7 8 9

“`

如果想要删除第2列和第3列的数据,可以使用以下命令:

“`

$ cut -f1 example.txt

“`

输出结果如下:

“`

“`

这个命令告诉Linux只提取每行中的第1个字段,即第1列数据,而忽略第2和第3列数据。

如果想要删除多列数据,只需要多次使用cut命令即可。例如,如果想同时删除第2和第3列数据,可以使用以下命令:

“`

$ cut -f1 example.txt | paste – – -d’ ‘

“`

输出结果如下:

“`

1

4

“`

这个命令首先使用cut命令提取出每行的第1列数据,然后使用paste命令将每行的第1列数据以空格为分隔符拼接到一起输出。

方法二:使用awk命令

awk命令也是Linux中一个强大的工具,可以用于处理文本数据。

例如,下面是一个含有多列数据的文件example.txt:

“`

1 2 3

4 5 6

7 8 9

“`

如果想要删除第2列和第3列的数据,可以使用以下命令:

“`

$ awk ‘{print $1}’ example.txt

“`

输出结果如下:

“`

“`

这个命令告诉Linux只输出每行中的第1个字段,即第1列数据,而忽略第2和第3列数据。

如果想要删除多列数据,只需要在花括号内使用几个print语句即可。例如,如果想同时删除第2和第3列数据,可以使用以下命令:

“`

$ awk ‘{print $1,$4}’ example.txt

“`

输出结果如下:

“`

1 3

4 6

7 9

“`

这个命令告诉Linux输出每行中的第1和第4个字段,即第1和第3列数据,而忽略第2列数据。

方法三:使用sed命令

sed命令是Linux中一个流编辑器,可以用于编辑文本数据。

例如,下面是一个含有多列数据的文件example.txt:

“`

1 2 3

4 5 6

7 8 9

“`

如果想要删除第2列和第3列的数据,可以使用以下命令:

“`

$ sed ‘s/ [0-9]*//2; s/ [0-9]*//2’ example.txt

“`

输出结果如下:

“`

1

4

“`

这个命令告诉Linux在每行中删除第2和第3个数字,即第2和第3列数据。

如果想要删除多列数据,只需要在命令中使用更多的s命令即可。例如,如果想同时删除第2和第3列数据,可以使用以下命令:

“`

$ sed ‘s/ [0-9]*//2; s/ [0-9]*//2; s/ [0-9]*//2’ example.txt

“`

输出结果如下:

“`

1

4

“`

这个命令告诉Linux在每行中删除第2、第3和第4个数字,即第2、第3和第4列数据。

本文介绍了在Linux中删除多列数据的三种方法,包括使用cut命令、awk命令和sed命令。这些方法都有其各自的优点和适用场景,可以根据需要选择适合的方法进行操作。无论使用哪种方法,都需要小心谨慎,防止误删重要数据。

相关问题拓展阅读:

系统之家Linux下怎么删除某文件外的所有文件怎么办

删除制定文件(夹)之外的所有文件呢?

  1、方法1,比较麻烦的做法是:

  复制需要保留的文件到其他文件夹,然后将该目录删除, 然后将需要保留的移动 回来。

  mv keep 。。/ #保留文件(夹) keep

  rm -rf * #删除当前文件夹里的所有文件

  mv 。。/keep 。/ #将原来的东西移动回来

  2、方法2,需要在当前文件夹中进行:

  rm -rf !(keep) #删除keep文件之外的所有文件

  rm -rf !(keep1 | keep2) #删除keep1和keep2文件之外的所有文件

  3、方法3,当前文件夹中结合使用grep和xargs来处理文件名:

  ls | grep -v keep | xargs rm #删除keep文件之外的所有文件

  说明: ls先得到当前的所有文件和文件夹的名字, grep -v keep,进行grep正则匹配查找keep,-v参数决定了结果为匹配之外的结果,也就是的到了keep之外的所有文件名,然后 xargs用于从 标准输入获得参数 并且传递给后面的命令,这里使用的命令是 rm,然后由rm删除前面选择的文件。

  好处:使用了grep来正则表达式来匹配文件名字,可以一次保留多个文件,从而进行更加准确的处理。

  4、方法4,使用find命令代替ls,改进方法3从而能够处理制定文件夹的文件:

  find 。/test/ | grep -v keep | xargs rm #删除当前test文件夹中keep文件之外的所有文件

  说明,用grep而不用find -name选取名字,因为find选取名字时比较麻烦,对正则表达式支持不够,无法排除指定文件名。

  5、方法5,直接使用find命令删除其他文件:

  find 。/ -name ‘[^k][^e][^e][^p]*’ -exec rm -rf {} \; #删除keep以外的其他文件。

  find 。/ -name ‘[^k][^e][^e][^p]*’ | xargs rm -rf #删除keep以外的其他文件。推荐!

  说明:上面第二行的代码效率高些,原因在于删除多个文件时 -exec会启动多个进程来处理,而xargs会启动一个rm进程来处理。

关于linux删除多列的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 如何在Linux中删除多列数据 (linux删除多列)