cut命令详解
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cut命令详解相关的知识,希望对你有一定的参考价值。
参考技术A cut文件内容查看
显示行中的指定部分,删除文件中指定字段
显示文件的内容,类似于下的type命令。
说明
该命令有两项功能,其一是用来显示文件的内容,它依次读取由参数file所指明的文件,将它们的内容输出到标准输出上;其二是连接两个或多个文件,如cut fl f2 > f3将把文件fl和几的内容合并起来,然后通过输出重定向符“>”的作用,将它们放入文件f3中。
当文件较大时,文本在屏幕上迅速闪过(滚屏),用户往往看不清所显示的内容。因此,一般用more等命令分屏显示。
为了控制滚屏,可以按Ctrl+S键,停止滚屏;按Ctrl+Q键可以恢复滚屏。
按Ctrl+C(中断键可以终止该命令的执行,并且返回Shell提示符状态。
语法
cut(选项)(参数)
选项
-b:仅显示行中指定直接范围的内容;-c:仅显示行中指定范围的字符;-d:指定字段的分隔符,默认的字段分隔符为“TAB”;-f:显示指定字段的内容;-n:与“-b”选项连用,不分割多字节字符;--complement:补足被选择的字节、字符或字段;--out-delimiter=<字段分隔符>:指定输出内容是的字段分割符;--help:显示指令的帮助信息;--version:显示指令的版本信息。
参数
文件:指定要进行内容过滤的文件。
实例
1.例如有一个学生报表信息,包含No、Name、Mark、Percent:
cat test.txt
No Name Mark Percent01tom699102jack718703alex6898
使用 -f 选项提取指定字段:
cut-f1 test.txt
结果:
No010203
cut-f2,3 test.txt
结果:
Name Mark
tom 69jack 71alex 68
--complement 选项提取指定字段之外的列(打印除了第二列之外的列):
cut-f2 --complement test.txt
结果:
No Mark Percent016991027187036898
2.使用 -d 选项指定字段分隔符:
cat test2.txt
No;Name;Mark;Percent01;tom;69;9102;jack;71;8703;alex;68;98cut-f2 -d";" test2.txt
结果:
Name
tom
jack
alex
3.指定字段的字符或者字节范围
cut命令可以将一串字符作为列来显示,字符字段的记法:
N-:从第N个字节、字符、字段到结尾;
N-M:从第N个字节、字符、字段到第M个(包括M在内)字节、字符、字段;-M:从第1个字节、字符、字段到第M个(包括M在内)字节、字符、字段。
上面是记法,结合下面选项将摸个范围的字节、字符指定为字段:-b 表示字节;-c 表示字符;-f 表示定义字段。
例:
cat test.txt
abcdefghijklmnopqrstuvwxyz
abcdefghijklmnopqrstuvwxyz
abcdefghijklmnopqrstuvwxyz
abcdefghijklmnopqrstuvwxyz
abcdefghijklmnopqrstuvwxyz
打印第1个到第3个字符:
cut-c1-3 test.txt
结果:
abc
abc
abc
abc
abc
打印前2个字符:
cut-c-2 test.txt
结果:
ab
ab
ab
ab
ab
打印从第5个字符开始到结尾:
cut-c5- test.txt
结果:
efghijklmnopqrstuvwxyz
efghijklmnopqrstuvwxyz
efghijklmnopqrstuvwxyz
efghijklmnopqrstuvwxyz
efghijklmnopqrstuvwxyz
cutgrepawksed命令详解
cut\grep\awk\sed命令详解
1、cut命令详解及实例
(1)作用:提取文件中指定的列
语法格式:cut 选项 文件名
(2)选项作用:
-d 分隔符 按照指定的分割符进行分割
-f 列号 指定提取第几列
-c 字符范围 不依赖分割符来分割,而是通过字符范围进行字段提取
-b 字节数 以字节为单位进行分割。
(3)cut实际应用案例。
例1:cut的-d和-f选项的使用,列出/etc/passwd里面以冒号为分隔符的第一列内容。
[[email protected]~]# cut -d ‘:‘ -f 1 /etc/passwd
root
bin
daemon
adm
lp
sync
shutdown
………………………
例2:cut的-c选项使用,列出/etc/passwd里面的第1-5,9,10这几个字符的内容
[[email protected] ~]# cut -c 1-5,9,10 /etc/passwd
root::0
bin:x1:
daemo:2
adm:x4:
lp:x::l
sync::0
shutd:x
halt::0
………………………………
例3:cut的-b选项和-c选项在提取英文字母时效果差不多,提取中文时-b选项就不太好用了,最好使用-c选项,不然会乱码。
[[email protected] long]# cat 1.txt
一帆风顺
二月花开
三生有幸
四季发财
[[email protected] long]# cut -c 2 1.txt
帆
月
生
季
[[email protected] long]# cut -b 2 1.txt
o
2、grep命令详解及实例
(1)作用:用来提取文件中包含关键词的行
语法格式:cut 选项 文件名
(2)选项作用:
-A 数字 列出符合条件的行和下面 n 行
-B 数字 列出符合条件的行和上面 n 行
-c 统计符合条件的字符串的行数
-i 忽略大小写
-n 输出行号
-v 反向查找(取反)
-o 只输出文件中匹配到的部分。
-E 能使用扩展正则表达式。同egrep
扩展元字符:
+ 前一个字符匹配一次或任意多次
? 前一个字符匹配0次或1次
| 匹配两个或多个分支选择
() 匹配其整体为一个字符,即模式单元
(3)grep实际应用案例
例1:grep的-A和-B选项的使用,列出/etc/passwd文件中包含root的行并同时列出上面的一行和下面的两行内容。
[[email protected] ~]# grep -A2 -B1 root /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
例2:grep的-c选项的使用,统计系统中无法登陆系统的用户有多少。
[[email protected] ~]# grep -c nologin /etc/passwd
28
例3:grep的-n选项使用,列出/etc/passwd中包含root的行并输出行号。
[[email protected] ~]# grep -n root /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
11:operator:x:11:0:operator:/root:/sbin/nologin
例4:grep的-o和-i选项使用,列出/etc/passwd中的user字符并输出行号,不需要区分大小写。
[[email protected] ~]# grep -oin user /etc/passwd
14:User
20:user
20:User
21:User
24:user
28:user
例5:grep的-v选项的使用,列出/etc/passwd中不包含nologin的行。
[[email protected] ~]# grep -v nologin /etc/passwd
root:x:0:0:root:/root:/bin/bash
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
例6:grep的-E选项(同egrep)的使用
[[email protected] long]# cat 3.txt
goodmorning
goooood
good bay
langlanglang
[[email protected] long]# grep -E "(lang)+" 3.txt
langlanglang
[[email protected] long]# grep -E "goo+d" 3.txt
goodmorning
goooood
good bay
[[email protected] long]# grep -E ba? 3.txt
good bay
[[email protected] long]# grep -E "good morning|bay" 3.txt
goodmorning
good bay
3、awk命令详解及实战
(1)作用:强大的文本分析工具,用于处理和提取文件内容。
语法格式:awk‘条件 1{动作 1} 条件 2{动作 2} ……’文件名
条件:一般使用关系表达式作为条件
x>10 判断 x 变量是否大于 10
x==y 判断变量 x 是否等于变量 y
A ~B 判断字符串 A 中是否包含能匹配 B 表达式的字符串
A !~ B 判断字符串 A 中是否不包含能匹配 B 表达式的字符串
动作:分为格式化输出和流程控制输出
[[email protected] ~]# awk ‘{printf $1 "\t" $3"\n"}‘ /etc/hosts
127.0.0.1 localhost.localdomain
::1 localhost.localdomain
[[email protected] ~]# df -h | awk‘{printf $1 "\t" $2 "\t" $3 "\n"}‘
Filesystem Size Used
/dev/sda3 18G 9.9G
tmpfs 495M 0
/dev/sda1 283M 34M
awk的条件
awk 内置变量
awk中正则表达式匹配操作中经常用到的字符:
\ ^ $ . [] | () * // :通用的regexp元字符
+ : 匹配其前的单个字符一次以上,是awk自有的元字符,不适用于grep或sed等
? : 匹配其前的单个字符1次或0次,是awk自有的元字符,不适用于grep或sed等
(2)awk常用选项作用
-F分隔符 指定分隔符
-f脚本文件 调用脚本
-v 变量 定义变量
awk命令非常强大,这里就不一一举例了。
4、sed命令详解及实战
(1)作用:主要是来进行数据选取,替换,删除,新增的命令
语法格式:sed 选项 文件名
(2)常用选项的作用
-n 把经过 sed 命令处理的行输出到屏幕。
-e 允许对输入数据应用多条 sed 命令编辑。
-f 脚本文件 从 sed 脚本中读入 sed 操作。和 awk 命令的-f 非常类似。
-r 在 sed 中支持扩展正则表达式。
-i 直接修改读取的文件内容。
常用动作字符:
a 追加,在当前行后添加一行或多行。
c 行替换,用 c 后面的字符串替换原数据行。
i 插入,在当期行前插入一行或多行。
d 删除,删除指定的行。
p 打印,输出指定的行。
s 字串替换,用一个字符串替换另外一个字符串。格式为“行范围 s/旧字串/新字串/g”(和 vim 中的替换格式类似)
对 sed 命令我们要知道的是,它所有的修改都不会直接修改文件的内容,而
是在内存中进行处理然后打印到屏幕上,除了使用 -i选项才会保存到文本中。
(3)sed实际应用案例
例1:sed的-n选项和动作p的使用,输出文件1.txt的第二行内容。
[[email protected] long]# sed 2p 1.txt 不加-n选项默认输出文件全部内容
aaaaaaaaaaaa
bbbbbbbbbbbb
bbbbbbbbbbbb
cccccccccccc
dddddddddddd
eeeeeeeeeeee
ffffffffffff
[[email protected] long]# sed -n 2p 1.txt 加了-n只显示文件指定内容
bbbbbbbbbbbb
[[email protected] long]# sed -n 1~2p 1.txt 隔一行输出文件内容
aaaaaaaaaaaa
cccccccccccc
eeeeeeeeeeee
[[email protected] long]# sed -n 1~3p 1.txt 隔两行输出文件内容
aaaaaaaaaaaa
dddddddddddd
例2:sed的-i选项和动作d的使用,删除指定的行。
[[email protected] long]# sed 2d 1.txt 删除第二行
aaaaaaaaaaaa
cccccccccccc
dddddddddddd
eeeeeeeeeeee
ffffffffffff
[[email protected] long]# cat 1.txt 查看第二行还在
aaaaaaaaaaaa
bbbbbbbbbbbb
cccccccccccc
dddddddddddd
eeeeeeeeeeee
ffffffffffff
[[email protected] long]# sed -i 2d 1.txt 加-i选项再删除第二行
[[email protected] long]# cat 1.txt 查看第二行已经删除了
aaaaaaaaaaaa
cccccccccccc
dddddddddddd
eeeeeeeeeeee
ffffffffffff
提示:sed只要不加-i选项就不会真正的修改文件内容。
例3:sed的动作a和动作i的使用,指定在第几行后面或前面追加内容。
[[email protected] long]# sed "3a 333333333333333333" 1.txt
aaaaaaaaaaaa
cccccccccccc
dddddddddddd
333333333333333333
eeeeeeeeeeee
ffffffffffff
[[email protected] long]# sed "3i 333333333333333333" 1.txt
aaaaaaaaaaaa
cccccccccccc
333333333333333333
dddddddddddd
eeeeeeeeeeee
ffffffffffff
例4:sed的动作c的使用,指定替换第几行内容
[[email protected] long]# sed "2c 11111111111" 1.txt
aaaaaaaaaaaa
11111111111
dddddddddddd
eeeeeeeeeeee
ffffffffffff
例5:sed的字符替换使用,和vi中的替换差不多。
[[email protected] long]# sed 1,3s/^/#/g 1.txt
#aaaaaaaaaaaa
#cccccccccccc
#dddddddddddd
eeeeeeeeeeee
ffffffffffff
例6:使用sed的-e选项进行多条sed操作,1和2行前面加@,删除第5行,替换第3行。
[[email protected] long]# sed -e "1,2s/^/@/g;5d;3c3333333333" 1.txt
@aaaaaaaaaaaa
@cccccccccccc
3333333333
eeeeeeeeeeee
本文出自 “成长中的强大” 博客,请务必保留此出处http://longlei.blog.51cto.com/12685458/1978807
以上是关于cut命令详解的主要内容,如果未能解决你的问题,请参考以下文章