如何根据关键字查询缓存
若是是在文件的外面ui
grep -rl 关键字 目录
例如:查找/home下全部内容含有hello的文件。grep -rl ‘hello’ /home
r:递归目录与子目录查找
l:只列出文件全名命令行
若是是在没有打开文件的前提就用"cat 文件名 | grep "关键字""htm
若是是用vi打开文件后,在命令行下输入“: /关键字” 按n会跳到下一个 , 按N会跳到上一个blog
若是要取消的话,则输入 :set nonu
行号的设置是vi的环境设置,不会影响文本的内容。递归
在用vi打开文件后,怎么替换某个关键字get
1. 基本替换 :s/str1/str2/ 替换当前行第一个str1为str2 :s/str1/str2/g 替换当前行全部str1为str2 :n,$s/str1/str2/ 替换第 n 行开始到最后一行中每一行的第一个str1为str2 :n,$s/str1/str2/g 替换第 n 行开始到最后一行中每一行全部str1为str2 (n 为数字,若 n 为 .,表示从当前行开始到最后一行) :%s/str1/str2/(等同于 :g/str1/s//str2/) 替换每一行的第一个str1为str2 :%s/str1/str2/g(等同于 :g/str1/s//str2/g) 替换每一行中全部str1为str2 2. 能够使用 # 做为分隔符,此时中间出现的 / 不会做为分隔符 :s#str1/#str2/# 替换当前行第一个str1/ 为str2/
在VI的命令模式下输入“:set nu” 完整的是 “:set number”ast
多文件的关键字替换 ,三种方式扩展
Mahuinan法:sed
sed -i "s/oldString/newString/g" `grep oldString -rl /path/*.txt`
Sumly法
执行命令:
perl -p -i -e "s/China/Sumly/g" /www/*.htm /www/*.txt
上面的意思是说将www文件夹下全部的htm和txt文件中的“China”都替换为“Sumly”
30T法
执行命令:
perl -pi -e 's|baidu|30T|g' `find /www -type f`
上面的意思是说将www文件夹下全部文件,不分扩展名,全部的“baidu”都替换为“30T”
复制操做
yy命令复制当前整行的内容到vi缓冲区
yw复制当前光标所在位置到单词尾字符的内容到vi缓存区,至关于复制一个单词
y$复制光标所在位置到行尾内容到缓存区
y^复制光标所在位置到行首内容到缓存区
nyy例如:5yy就是复制5行
nyw例如:2yw就是复制两个单词
若是要复制第m行到第n行之间的内容,能够在末行模式中输入m,ny例如:3,5y复制第三行到第五行内容到缓存区。
粘贴
p:在光标所在位置的后面插入复制的文本,p是paste的首字母。
P:在光标所在位置的前面插入复制的文本。
np:在光标所在位置的后面插入复制的文本,共复制n次。
nP:在光标所在位置的前面插入复制的文本,共复制n次。