1.功能:
cut命令从文件的每一行剪切字节、字符和字段并将它们写至标准输出,以文件的每一行作为处理对象的。
2.用法:
cut [选项] [范围] 文件。选项用来指定单位(字节、字符还是字段),范围指定选项的位置。
3.参数:
-b:指定以字节为单位显示选中内容
-c:指定以字符为单位显示选中内容
-f:指定以字段为单位显示选中内容
-d:指定字段的分界符,默认为制表符
其它的选项还有-n(仅和-b选项一起使用)、-s(仅和-f选项一起使用)
范围表示:
n:第n个字节/字符/字段
n-:从第n个字节/字符/字段到最后一个字节/字符/字段
n-m:从第n个字节/字符/字段到第m个字节/字符/字段,包括m
-m:从行的开头到第m个字节/字符/字段,包括m
-:从行开头到行的最后
4.例子
4.1 按字节cut
注意:一个空格算一个字节,一个汉字算三个字节
date 命令中,1-4位是年份,第5位是汉字,占了3个字节,要取到第7位才能取到“年”字
[root@mysql sale_list]# date
2016年 06月 21日 星期二 16:52:22 CST
[root@mysql sale_list]# date |cut -b 1-4
2016
[root@mysql sale_list]# date |cut -b 1-5
2016
[root@mysql sale_list]# date |cut -b 1-6
2016
[root@mysql sale_list]# date |cut -b 1-7
2016年
4.2 按字符cut
中文字符和空格都算一个字符。
[root@mysql sale_list]# date |cut -c 1-4
2016
[root@mysql sale_list]# date |cut -c 1-5
2016年
由于中文只算一个字符,所以取到第5位就可以显示“年”字。
4.3 按字段cut
[root@mysql sale_list]# date#以空格为分隔符,date命令中有6个字段
2016年 06月 21日 星期二 16:57:44 CST
[root@mysql sale_list]# date |cut -d" " -f 1
2016年
[root@mysql sale_list]# date |cut -d" " -f 2
06月
[root@mysql sale_list]# date |cut -d" " -f 3
21日
[root@mysql sale_list]# date |cut -d" " -f 4
星期二
[root@mysql sale_list]# date |cut -d" " -f 5
16:58:48
[root@mysql sale_list]# date |cut -d" " -f 6
CST
[root@mysql sale_list]# date |cut -d" " -f 1-3 #范围显示
2016年 06月 21日
[root@mysql sale_list]# date |cut -d" " -f 1-3,4-5#范围显示
2016年 06月 21日 星期二 16:58:57