linux sed cut,Linux的文本编辑diff & cut & echo & sed & awk & grep

一、文本文件比较命令diff1.diff命令的功能

Linux中diff命令的功能为逐行比较两个文本文件,列出其不同之处。它对给出的文件进行系统的检查,并显示出两个文件中所有不同的行,不要求事先对文件进行排序。

格式

diff  [num1,num2][a|c|d][num3,num4]

a        添加(a,代表addition)

c        改变(c,代表change)

d        删除(d,代表deletion)

num1,num3    第一个文件的内容

num3,num4    第二个文件的内容

创建file和file1文件

比较file和file1,显示2d1,表示第二行删除123变成第二个

比较file1和file,显示2a1,表示第一行增加123变成第二个

6af6a103a06b779efed0109a33dd5866.png

创建file和file1文件

比较file和file1,显示2c2,表示第二行有变化,第一个删除123,第二个删除124后一样

比较file1和file,显示2c2,表示第二行有变化,第一个删除124,第二个删除123后一样

fdc0b2be2ac12e1e1836fa685e33d16d.png

2.diff生成patch文件

3b2de72af02239877494f18210e6bc65.png

diff -u file file1 > file.path     file与file1的差别导入到file.path

patch  file file.path               不备份源文件

patch -b file file.path           -b表示备份原文件为file.orig

11592c0db1853d4dcab40488a7122b52.png

二.grep(关键字: 截取)

1.作用

Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

2.格式

grep [options]

3.主要参数

[options]主要参数:

-c:只输出匹配行的计数。

-I:不区分大 小写(只适用于单字符)。

-h:查询多文件时不显示文件名。

-l:查询多文件时只输出包含匹配字符的文件名。

-n:显示匹配行及 行号。

-s:不显示不存在或无匹配文本的错误信息。

-v:显示不包含匹配文本的所有行。

pattern正则表达式主要参数:

\: 忽略正则表达式中特殊字符的原有含义。

^:匹配正则表达式的开始行。

$: 匹配正则表达式的结束行。

\

\>:到匹配正则表达式的行结束。

[ ]:单个字符,如[A]即A符合要求 。

[ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求 。

。:所有的单个字符。

* :有字符,长度可以为0。

grep -n显示行号

469c1b0102a7b01ae20ac9cf023196ef.png

grep -n3 显示上下3行

23a3e4016190865f0bfbf526a5d6e275.png

grep -A3 显示下面3行

63d8d1888aa3adc90e179ad12175c358.png

grep -B3 显示上面3行

8af67989964b953e1a5e02d23ad41934.png

grep -i 忽略大小写

149e95d19aa50cff2a509ddcea308f10.png

grep -v 取反

ed1a5a3d5681205580ef5f259a436b57.png

grep -E 多重过滤

03cacfe3792b32e6fe40c8b70f95d208.png

grep ^root 以root开头

1c8f7a223e7d8a1cf17d6271783ead6b.png

grep root$ 以root结尾

b00ffbb1b9ddccc360aed8d2baa11be3.png

grep "\

fdb1ef2a510e6acf4a48c4967f42a1fb.png

grep "root\>" 以root结束

5df01dab6b995d8f55f56c1472ff902a.png

grep "\"以root开始以root结束 忽略大小写

5f5ef1f159f06255ad03b8f1ef6b6b29.png

三.cut

cut在文件中负责剪切数据用的。cut是以每一行为一个处理对象的,这种机制和sed是一样的。

剪切依据

-d 指定分割符号

cut命令主要是接受三个定位方法:

1.字节(bytes),用选项-b

3ebbf83eb28627ed377b92f4a8764aa4.png

2.字符(characters),用选项-c

25f1e6a9bc55229a07bfdc772e7dfff3.png

3.域(fields),用选项-f

f1922fe4737827a7fd2920105108b49a.png

四.seq顺序

seq 开始 间隔 结尾

b2d97092c041cf99de9dcf3eb281dfe4.png

五.echo

echo是一种最常用的与广泛使用的内置于Linux的bash和C shell的命令,通常用在脚本语言和批处理文件中来在标准输出或者文件中显示一行文本或者字符串。

\a 发出警告声;

\b 删除前一个字符;

\c 最后不加上换行符号;

\f 换行但光标仍旧停留在原来的位置;

\n 换行且光标移至行首;

\r 光标移至行首,但不换行;

\t 插入tab;

\v 与\f相同;

\\ 插入\字符;

\nnn 插入nnn(八进制)所代表的ASCII字符;

echo -n   换行

echo -e

echo -e "\r    \r"

六.awk(关键字:分析&处理)

一行一行的分析处理 awk '条件类型1{动作1}条件类型2{动作2}' filename, awk 也可以读取来自前一个指令的 standard input

相对于sed常常用于一整行处理, awk则比较倾向于一行当中分成数个"字段"(区域)来处理, 默认的分隔符是空格键或tab键

例如:

last -n 5 | awk '{print $1 "\t" $3}'  这里大括号内$1"\t"$3 之间不加空格也可以, 不过最好还是加上个空格, 另外注意"\t"是有双引号的, 因为本身这些内容都在单引号内

$0 代表整行 $1代表第一个区域, 依此类推

awk的处理流程是:

1. 读第一行, 将第一行资料填入变量 $0, $1... 等变量中

2. 依据条件限制, 执行动作

3. 接下来执行下一行

所以, AWK一次处理是一行, 而一次中处理的最小单位是一个区域

另外还有3个变量, NF: 每一行处理的字段数, NR 目前处理到第几行 FS 目前的分隔符

逻辑判断 > < >= <= == !== , 赋值直接使用=

cat /etc/passwd | awk '{FS=":"} $3<10 {print $1 "\t" $3}'

首先定义分隔符为:, 然后判断, 注意看, 判断没有写在{}中, 然后执行动作, FS=":"这是一个动作, 赋值动作, 不是一个判断,

所以不写在{}中

BEGIN END , 给程序员一个初始化和收尾的工作, BEGIN之后列出的操作在{}内将在awk开始扫描输入之前执行, 而END{}内的操作, 将在扫描完输入文件后执行.

awk '/test/ {print NR}' abc 将带有test的行的行号打印出来, 注意//之间可以使用正则表达式

awk {}内, 可以使用 if else ,for(i=0;i<10;i++), i=1 while(i

可见, awk的很多用法都等同于C语言, 比如"\t" 分隔符, print的格式, if, while, for 等等

awk 是相当复杂的工具, 真正使用时, 再补充吧. (有关工具的picture)

TEST="#################################"

awk -F 分隔符 -v TEST=$TEST  'BEGIN {print TEST} {print $2} END{print TEST}' passwd

awk -F ":" -v TEST=$TEST 'BEGIN {print TEST ":"} {print $2} END{print TEST}' passwd

6ef27e9bfe807cebf543dbea99b754a1.png

七.sed(关键字: 编辑)

1. Sed简介

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当 前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命 令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输 出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。

2. 定址

可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围可以通过数据,正则表达式或者二者结合的方式确定。

3. Sed命令格式

调用sed命令有两种形式:

sed [options] 'command' file(s)

sed [options] -f scriptfile file(s)

4.常见的Sed命令

a  在当前行后面加入一行文本。

b label 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。

c  用新的文本改变本行的文本。

d  从模板块(Pattern space)位置删除行。

D  删除模板块的第一行。

i  在当前行上面插入文本。

h  拷贝模板块的内容到内存中的缓冲区。

H  追加模板块的内容到内存中的缓冲区

g  获得内存缓冲区的内容,并替代当前模板块中的文本。

G  获得内存缓冲区的内容,并追加到当前模板块文本的后面。

l  列表不能打印字符的清单。

n  读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。

N  追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。

p  打印模板块的行。

P(大写)打印模板块的第一行。

q  退出Sed。

r file  从file中读行。

t label  if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。

T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。

w file  写并追加模板块到file末尾。

W file  写并追加模板块的第一行到file末尾。

!  表示后面的命令对所有没有被选定的行发生作用。

s/re/string  用string替换正则表达式re。

=  打印当前行号码。

#  把注释扩展到下一个换行符以前。

以下的是替换标记

g表示行内全面替换。

p表示打印行。

w表示把行写入一个文件。

x表示互换模板块中的文本和缓冲区中的文本。

y表示把一个字符翻译为另外的字符(但是不用于正则表达式)

sed 's/bin/westos/g' passwd

6a5414443a7f9d7848f408f87d29d79a.png

sed '1,5s/westos/redhat/g' passwd

199f88ef3bf7883396bab9cc1d9bc670.png

sed '/lp/,/shutdown/s/sbin/westos/g' passwd

sed -e 's/sbin/westos' -e 's/nologin/redhat' passwd

sed -5d passwd

sed -5p passwd

sed -n 5p passwd

vim file

s/sbin/westos/g

s/nologin/lee/g

sed -f file passwd

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值