":%s/\r/,/g" 是一个 Vim 的命令,表示将当前文件中的所有回车符("\r")替换为逗号(",")。
具体来说,这个命令由三部分组成:
":":表示输入命令模式。
"%s":表示对当前文件中的所有行进行替换 *** 作。
"/\r/,/g":表示将文件中的所有回车符替换为逗号。
执行这个命令后,Vim 会在当前文件中执行批量替换 *** 作,将所有回车符替换为逗号。
注意:这个命令只适用于 Vim 编辑器,其他编辑器可能不支持。
1、vi命令下的查找和替换1.1 vi下的查找
/hello<Enter>:向下查找hello匹配字符串
?hello<Enter>:向上查找hello匹配字符串
使用了查找命令之后,使用如下两个键快速查找:
n:按照同一方向继续查找
N:按照反方向查找
hello是需要匹配的字符串,例如:
/name<Enter> #查找name
/name<Enter> #查找name单词(注意前后的空格)
除此之外,hello还可以使用一些特殊字符,包括(/、^、$、*、.),其中前三个这两个是vi与vim通用的,“/”为转义字符。
/^name<Enter> #查找以name开始的行
/name$<Enter> #查找以name结束的行
//^name<Enter> #查找^name字符串
1.2 vi下的替换
:s/name/title/ #替换当前行第一个 name 为 title
:s/name/title/g #替换当前行所有 name 为 title
:n,$s/name/title/ #替换第 n 行开始到最后一行中每一行的第一个 name 为 title
:n,$s/name/title/g #替换第 n 行开始到最后一行中每一行所有 name 为 title
#(n 为数字,若 n 为 .,表示从当前行开始到最后一行)
:%s/name/title/ #(等同于 :g/name/s//title/) 替换每一行的第一个 name 为 title
:%s/name/title/g #(等同于 :g/name/s//title/g) 替换每一行中所有 name 为 title
可以使用 #或+ 作为分隔符,此时中间出现的 / 不会作为分隔符
:s#name/#title/# 替换当前行第一个 name/ 为 title/
:%s+/oradata/apras/+/user01/apras1+ (
使用+ 来 替换 / ): /oradata/apras/替换成/user01/apras1/
2.sed和grep配合
命令:sed -i s/yyyy/xxxx/g `grep yyyy -rl --include="*.txt" ./`
作用:将当前目录(包括子目录)中所有txt文件中的yyyy字符串替换为xxxx字符串。其中,
-i 表示 *** 作的是文件,``括起来的grep命令,表示将grep命令的的结果作为 *** 作文件。
s/yyyy/xxxx/表示查找yyyy并替换为xxxx,后面跟g表示一行中有多个yyyy的时候,都替换,而不是仅替换第一个
另外,如果不需要查找子目录,仅需要在当前目录替换,用sed命令就行了,命令如下:sed -i s/xxxx/yyyy/g ./*.txt
3.find命令查找和替换
命令格式:find -name '要查找的文件名' | xargs perl -pi -e 's|被替换的字符串|替换后的字符串|g'
#查找替换当前目录下包含字符串并进行替换
find -name '*.txt' | xargs perl -pi -e 's|江苏|上海|g'
#递归查找替换
find . -type f -name '*.html' | xargs perl -pi -e 's|苏州|上海|g'
awk格式化:前面接触到的awk的输出功能,是{print}的功能,只能对文本简单的输出,并不能美化或修改格式printf格式化输出:对文本格式化输出
printf和print的区别:format的使用
要点
1、其与print命令的最大不同是,printf需要指定format
2、format用于指定后面的每个item的输出格式
3、printf语句不会自动打印换行符;\nprint默认添加空格换行符
format格式的指示符都以%开头,后跟一个字符
%c 显示字符的ASCII码
%d, %i 十进制整数
%e, %E 科学计数法显示数值
%f 显示浮点数
%g, %G 以科学计数法的格式或浮点数的格式显示数值
%s 显示字符串
%u 无符号整数
%% 显示%自身
printf修饰符
- 左对齐;默认右对齐
+ 显示数值符号;printf "%+d"
给printf添加格式
格式化字符串%s代表字符串的意思
awk '{printf "%s\n",$1}' file
对对个变量进行格式化
当我们使用Linux命令printf时,一个%s格式替换符,可以对多个参数进行重复格式化
printf "%s\n" a b c d
然而awk的格式替换符想要修改多个变量,必须传入多个
awk 'BEGIN{printf "%d\n%d\n%d\n%d\n%d\n",1,2,3,4,5}'
注意awk不跟上文件数据,必须添加BEGIN, %d代表的是十进制数字
awk通过空格切割文档,printf动作对数据格式化输出
awk '{printf "第一列:%s第二列:%s第三列:%s\n", 2,$3}' file
对pwd.txt进行格式化输出
awk -F ":" 'BEGIN{printf
"%-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %-25s\n",
"用户名","密码","UID","GID","用户注释","用户家目录","用户使用的解释器"}
{printf "%-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %s\n",
2, 4, 6,$7}'
pwd.txt
参数解释
'BEGIN{printf "格式替换符 格式替换符2","变量1","变量2"}' 执行BEGIN模式
"%-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %-25s\t %-25s\n" 先打印第一行信息
%s是格式替换符 ,替换字符串
%s\t 格式化字符串后,添加制表符,四个空格
%-25s 已然是格式化字符串, - 代表左对齐 ,25个字符长度
printf对输出的文本不会换行,必须添加对于的格式替换符和\n
使用printf动作,'{printf "%s\n",$1}',替换的格式和变量之间得有逗号
使用printf动作,%s %d 等格式化替换符,必须和被格式化的数据一一对应
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)