写在前面,有一文本a.txt,内容如下
name=zjf
num=001
happy=yes
需要使用grep取得happy一行的行号,方法如下:
grep -n happy ./a.txt | cut -f1 -d":"
解释一下:
1. 使用grep在取出的内容前面添加行号,结果为230:happy=yes
2. 对上面结果操作,取分隔符“:”前面内容,即230。(若为-f2,则表示取“:”后面的内容happy=yes)
当然,用sed也是可以实现该功能的,比如:sed -n '/happy/=' ./a.txt ,会直接显示行号3。
sed的用法可以看这里
对于cut的使用,最常用的就只有下面几种方法,从网上摘录一段。
cut -b list [-n] [file ...]
cut -c list [file ...]
cut -f list [-d delim][-s][file ...]
上面的-b、-c、-f分别表示字节、字符、字段(即byte、character、field);
list表示-b、-c、-f操作范围,-n常常表示具体数字;
file表示的自然是要操作的文本文件的名称;
delim(英文全写:delimiter)表示分隔符,默认情况下为TAB;
-s表示不包括那些不含分隔符的行(这样有利于去掉注释和标题)
下面说说list所指的范围表示方法:
范围的表示方法:
N 只有第N项
N- 从第N项一直到行尾
N-M 从第N项到第M项(包括M)
-M 从一行的开始到第M项(包含M)
- 从一行的开始到结束的所有项
可以随便使用一个文本进行测试,单独取一行可以配合grep来使用,cut命令可以从一个文本文件或者文本流中提取文本列。