cut/sed常用积累

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cut/sed常用积累相关的知识,希望对你有一定的参考价值。

cut 主要用法:

第一,字节(bytes),用选项-b
第二,字符(characters),用选项-c
第三,域(fields),用选项-f

一:

who|cut -b 3-5,11 (-b后面的无论怎么写,都会按数字顺序排列截取展示)
who|cut -b -2
who|cut -b 2-

cut -c的用法和cut -b用法基本相似,只是一个字符和字节的区别

依据间隔符来进行截取:

cut -d : -f -2
cut -d : -f 2-
cut -d : -f 3-5,1

配注:cut只擅长处理“以一个字符间隔”的文本内容!

sed 主要用法:

sed 是一个管道命令,主要以行为单位进行处理,可以将数据行进行替换、删除、新增、选取等

sed -d ---删除行 (实际文本内容并没改变,只是输出显示内容的控制)

sed ‘1d‘ lych.txt # 输出删除第一行后的文件内容

sed ‘$d‘ lych.txt # 输出删除最后一行后的文件内容

sed ‘1, 2d‘ lych.txt # 输出删除第一行到第二行的文件内容

sed ‘2, $d‘ lych.txt # 输出删除第2行到最后1行后的文件内容

sed -n 显示行

sed -n ‘1p‘ lych.txt # 只显示文件的第一行

sed -n ‘$p‘ lych.txt # 只显示文件的最后一行

sed -n ‘1, 2p‘ lych.txt # 只显示文件的第一行到第二行

sed -n ‘2, $p‘ lych.txt # 显示文件的第二行到最后一行

sed -a 增加字符

在第一行后增加一行:

sed ‘1a drink tea‘ lych.txt

在第一行和第三行后增加一行:

sed ‘1,3a drink tea‘ lych.txt

增加两行,\ 两边分别是两行的内容

sed ‘1a drink tea\nor coffee‘ lych.txt

sed -c 替代行

sed ‘1c Hi‘ lych.txt # .第一行替换为Hi

sed ‘1,2c Hi‘ lych.txt # 第一行到第二行替换为Hi

sed -s 替换字符内容

sed ‘s/ruby/bird/g‘ lych.txt # 把全部的ruby替换为bird

sed ‘s/ruby//g‘ lych.txt # 把全部的ruby替换为空,即删除ruby字符串

sed -i 多场景

对每行匹配到的第一个字符串进行替换

sed -i ‘s/原字符串/新字符串/‘ lych.txt

对全局匹配上的所有字符串进行替换

sed -i ‘s/原字符串/新字符串/g‘ lych.txt

删除所有匹配到字符串的行

sed -i ‘/匹配字符串/d‘ lych.txt

特定字符串的行后插入新行

sed -i ‘/特定字符串/a 新行字符串‘ lych.txt

特定字符串的行前插入新行

sed -i ‘/特定字符串/i 新行字符串‘ lych.txt

把匹配行中的某个字符串替换为目标字符串

sed -i ‘/匹配字符串/s/源字符串/目标字符串/g‘ lych.txt

在文件ab.txt中的末行之后,添加bye

sed -i ‘$a bye‘ lych.txt

对于文件第3行,把匹配上的所有字符串进行替换

sed -i ‘3s/原字符串/新字符串/g‘ lych.txt

以上是关于cut/sed常用积累的主要内容,如果未能解决你的问题,请参考以下文章

大数据技术学习路线,该怎么学?

大数据技术学习路线,有信心能学好的朋友,就开始吧

Shell工具cut/sed/awk/sort

replace 常用积累

SQL常用语句积累

7Shell工具 cut sed awk sort