筛选出几列数据均等0的行 Linux,Shell cut命令:查找符合条件的行

grep 命令是在文件中提取符合条件的行,也就是分析一行的信息,如果行中包含需要的信息,就把该行提取出来。而如果要进行列提取,就要利用 cut 命令了。

不过要小心,虽然 cut 命令用于提取符合条件的列,但是也要一行一行地进行数据提取。也就是说,先要读取文本的第一行数据,在此行中判断是否有符合条件的字段,然后再处理第二行数据。我们也可以把 cut 成为字段提取命令。命令格式如下:

[root@localhost ~]# cut [选项] 文件名

选项:

-f 列号:提取第几列;

-d 分隔符:按照指定分隔符分割列;

-c 字符范围:不依赖分隔符来区分列,而是通过字符范围(行首为 0)来进行字段提取。"n-"表示从第 n 个字符到行尾;"n-m"表示从第 n 个字符到第 m 个字符;"-m"表示从第 1 个字符到第 m 个字符;

cut 命令的默认分隔符是制表符,也就是 Tab 键,不想对空格符支持得不怎么好。我们先建立一个测试文件,然后看看 cut 命令的作用。

[root@localhost ~]# vi student.txt

ID Name gender Mark

1 Liming M 86

2 Sc M 90

3 Gao M 83

建立学员成绩表,注意这张表中所有的分隔符都是制表符,不能是空格,否则后面的实验会出现问题。

先看看 cut 命令该如何使用:

[root@localhost ~]# cut -f 2 student.txt

#提取第二列的内容

Name

Liming

Sc

Gao

如果想要提取多列呢?将列号直接用","隔开,命令如下:

[root@localhost ~]# cut -f 2,3 student.txt

#提取第二列和第三列的内容

Name gender

Liming M

Sc M

Gao M

cut 命令可以按照字符进行提取。需要注意的是,"8-"代表提取所有行从第 8 个字符到行尾,而"10-20"代表提取所有行的第 10~20 个字符,而"-8"代表提取所有行从行首到第 8 个字符,命令如下:

[root@localhost ~]#cut-c 8- student.txt

#提取取每行从第8个字符到行尾,好像很乱啊,那是因为每行的字符个数不相等

gender Mark

g M 86

90

83

当然,cut 命令也可以手工指定分隔符。例如,我想看看当前 Linux 服务器中有哪些用户、这些用户的 UID 是什么,就可以这样操作:

[root@localhost ~]# cut -d ":" -f 1,3 /etc/passwd

#以":"作为分隔符,提取/etc/passwd文件的第一列和第三列

root:0

bin:1

daemon:2

adm:3

lp:4

cut 命令很方便,不过最主要的问题是对空格识别得不好,很多命令的输出格式中都不是制表符,而是空格符,比如:

[root@localhost ~]# df

#统计分区使用状况

文件系统 1K-块 已用 可用 已用% 挂载点

/dev/sda3 19923216 1848936 17062212 10% /

tmpfs 312672 0 312672 0% /dev/shm

/dev/sda1 198337 26359 161738 15% /boot

/dev/srO 3626176 3626176 0 100% /mnt/cdrom

如果想用 cut 命令截取第一列和第三列,就会出现这样的情况:

[root@localhost ~]# df -h|cut -d""-f 1,3

文件系统

/dev/sda3

tmpfs

/dev/sda1

/dev/sr0

第三列去哪里了?其实因为 df 命令输出的分隔符不是制表符,而是多个空格符,所以 cut 命令会忠实地将每个空格符当作一个分隔符,而这样数,第三列刚好也是空格,所以输出才会是上面这种情况。

总之,cut 命令不能很好地识别空格符。如果想要以空格符作为分隔符,建议使用 awk 命令。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值