vim与正则表达式

vim与正则表达式,第1张

纯文本文件 :由ASCII, Unicode 或其它编码的纯文字的文件

文本文件编辑工具:

vi ——Visual editor,文本编辑器

vim ——VIsual editor iMproved ,和vi 使用方法一致, 但功能更为强大

vim分很多种工作模式, *** 作之前 首先明确当前处于哪个模式

首要快捷键:模式之间相互切换

说明:

打开vim默认进入命令模式,所有按键 *** 作在屏幕上不可见!!!

命令模式功能强大,只是 按键时看不到输入内容 ,所以需要大量的记忆才能更好的使用

ZZ 保存并退出

ZQ 不保存退出

字符间跳转:

单词间跳转:

句间移动:

段落间移动:

行间移动:

行首行尾跳转:

当前页跳转:

命令模式翻屏野凳衫 *** 作:

在命令模式下也能进行部分编辑 *** 作

y 复制,行为相似于d剪切

同理也可以结合光标跳转字符,实现范围 *** 作

!!!应注意:单独按 d 或 y 是不起作用的

与 d 的功能完全一致,但是 完成 *** 作后自动切换到插入模式

比如:

cc :即为删除本行并进入插入模式,cc=S

C:删除当前光标到行尾,并切换成插入模式,相当于c$

特别地: 范围 *** 作

按“ : ”进入Ex模式 ,创建一个命令提示符: 处于底部的屏幕左侧

以行为基本单位

地址定界后跟一个编辑命令,即可进行批量范围 *** 作

特别地,s///也可以换为s@@@...等其他字符

以上所有设置的关闭方式相同:set noCMD

永久保存设置,保存在配置目录

用方向键和其他字符跳跃快捷键模拟鼠标选中 *** 作

被选中的文字可被删除,复制,变更,过滤,搜索,替换等

进入此模式的快捷键:

单个文件切割后 相当于两个窗口同时显示同一个文件

寄存器即为 多个剪贴板

有26个 字母命名 寄存器和1个 无命 名寄存器,常存放不同的剪贴版内容, 可以不同会话间共享

未指定,将使用无命名寄存器, 即为普通的复制粘贴 *** 作

还有10个 数字寄存器 ,用0,1,…,9表示,0存放最近复制内容,1存放最近删除内容

当新的文颂腔本变更和删除时,1转存到2,2转存到3,以此类推

数字寄存器不能在不同会话间共享

作用是标记书签

输入ma :将当前位置标记为a

输入 'a 跳转到a标记的位置

26个字母均可做标记, mb 、 mc 等等

qa 录制宏 a,a为宏的名称

q停止录制宏

@a 执行宏 a

@@ 重新执行上次执行的宏

录制宏 是录制位置还是录制一系列 *** 作???

涉及 xxd 命令

1、在vim中设置tab缩进为4个字符

2、复制/etc/rc.d/init.d/functions文件至/tmp目录,替换/tmp/functions文件中的/etc/sysconfig/init为/var/log

3、删除/tmp/functions文件中所有以#开头,且#后面至少有一个空白字符的行 的行首的#号

cat 可以查看文本内容

特别地,若无指定文件 或文件名为 - ,表示从标准输入接收信息

Windows中的文本文件与Linux中格式有所不同

对于一些类似换行、Tab...等不可见字符,可使用 -A 选项进行显示

两种逆向显示:

文本 篇幅较大 时,用cat查看不太方便,此时应粗顷使用more命令

使用more命令查看, 移动到最后一行时自动退出

为了反复查看文件,可使用less命令 (less终端内 不显示进度百分比

与管道配合使用

若已知输出结果会是大篇幅内容,可提前用管道连接more或less

大篇幅文件,若 只需要查看前几行 ,可使用head命令

不指定行数,head默认输出前10行

特别地,行数为负数时,如head -n -5 表示 去除最后5行

与之相反,tail命令则表示 显示文件指定的最后几行

不指定默认输出最后10行 ,同样也支持 -c 字节数

特别地, tail命令行数前使用 + 号 ,如 -n +3 表示 从第3行往后全部输出

@@tail实用功能( -f 选项):持续监测文件是否有追加内容

cut 命令 以指定分隔符 对文本文件或STDIN数据的 每行内容进行切割

默认分隔符为TAB

三种类似功能:指定 字节b/字符c/字段f 序号或范围

不常用功能:-b 、 -c

-nb的作用:防止切割多字节字符(可认为等效于-c)

#已知每个汉字大小为3byte!!!

常用功能:-f(需要先用-d指定分隔符,不指定则为tab)

其他功能: 在输出结果中指定需要显示的分隔符

其他功能: 取反 complement

默认以行为单位 ,合并多个文件同行号的列到一行

合并文件的 拼接处默认以TAB分隔

对指定文本文件或STDIN的 各项指标进行统计

包括:文件的行总数、单词总数、字节总数和字符总数

不加选项时默认统计前三项

应用举例:

对文件的所有 行进行排序

默认:数字在字母之前、字母排序不分大小写

以行为单位去除重复内容(只去除连续重复行)

对比分析两个普通文件的不同之处 (命令cmp比较两个 二进制文件 的区别)

选项 -y可以并排对比 -W指定并排的间距

选项 -u 用来输出统一的(unified)diif格式文件 (适合用于补丁文件)

patch命令 :利用diff比较结果输出的内容进行 还原

cmp命令 :比较二进制程序的源码不同之处

排除过滤 - v

grep默认只显示符合条件的行,- v 选项 只显示不符合条件的内容

**忽略大小写- i **:gerp默认大小写敏感,- i 选项忽略大小写

显示行号 -n :文本过多时,显示行号方便查看

(显示 匹配结果在原文中的行号)

**显示行数量 - c **, 只显示有多少行符合条件

- o 只显示keywords :- o 只显示所有匹配的内容,可知 keywords数量

静默模式:- q 选项 执行命令但不输出结果,常用于脚本条件判断

ABC匹配结果附带前后行一起输出

选项 - e 多个条件满足其一 几个条件就有几次 - e

特别地, - E 表示使用扩展正则表达式

选项 - w 匹配单个单词

单词判断依据——字母数字下划线连续组合都视为单词

单词判断依据——字母数字下划线连续组合都视为单词

单词判断依据——字母数字下划线连续组合都视为单词

正则表达式把字符和次数分开表达

正则表达式把字符和次数分开表达

正则表达式把字符和次数分开表达

正则表达式把字符和次数分开表达

基本格式为 引号 括起来:

正则表达式的 元字符按功能分四类 ,下面分别介绍

指定某个内容出现的具体次数(keyword写在前)

只匹配前一个紧挨着的字符!!!!! !!!!!!!!!!!!!

在指定位置搜索 字符串

分组:将多个字符 作为整体 来进行处理

普通分组用法:

后向引用: 使用分组之后,后续再次引用只需要 使用 、 等表示第一个、第二个分组

最适合用于vim搜索替换(形如 r..t 替换成 r..ter 的情况)

逻辑 或

除了使用选项 - e 还有符号 \| (其中\用来转义)

为了在复杂规则中更加直观, 省略了转义符 \

去重之前先排序

1、 打开Vim 输入 下面代码进行 排序悄搭举

: sort

2、进行去重

:g/^\(.*\)$\n\1$/d

另外还有一些别的命启碧令,也可以试一试

:g/\%(^\1$\n\)\@<=\(.*\)$/d //功能同上,也是去枝锋除重复行

:g/\%(^\1\>.*$\n\)\@<=\(\k\+\).*$/d //功能同上,也是去除重复行

打开CSDN APP,看更多技术内容


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12291530.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存