马哥教育第三周

最后都变了- 提交于 2020-04-05 18:41:38

vim命令格式

     +#   打开文件后,让光标处于第#行的行首,+默认行尾
     +/PATTERN   让光标处于第一个被PATTERN匹配到的行行首
      -b file 二进制方式打开文件
      -d file1 file2… 比较多个文件,相当于 vimdiff
      -m file 只读打开文件
      -e file   直接进入ex模式,相当于执行ex file
说明:
     如果该文件存在,文件被打开并显示内容
     如果该文件不存在,当编辑后第一次存盘时创建它
命令模式-->插入模式 
    i insert, 在光标所在处输入
    I 在当前光标所在行的行首输入
    a append, 在光标所在处后面输入
    A 在当前光标所在行的行尾输入
    o 在当前光标所在行的下方打开一个新行
    O在当前光标所在行的上方打开一个新行
插入模式 --- ESC-----> 命令模式
命令模式 ---- : ----> 扩展命令模式
扩展命令模式 ----ESC,enter----> 命令模式
扩展命令模式基本命令             退出VIM
     w 写(存)磁盘文件                 ZZ  保存退出
     wq 写入并退出                          ZQ  不保存退出
      x 写入并退出
      X   加密
      q 退出
      q! 不存盘退出,即使更改都将丢失
      r   filename 读文件内容到当前文件中
      w   filename 将当前文件内容写入另一个文件
      !command 执行命令
      r!command 读入命令的输出
行号:显示简写 set nu,取消显示简写 set nonu
忽略字符的大小写:启用简写 set ic, 不忽略 set noic
自动缩进:启用简写 set ai, 禁用 set noai
复制保留格式:启用set paste,禁用 set nopaste
显示Tab和换行符 ^I 和$显示:启用 set list, 禁用set nolist
删除命令        d 删除命令,可结合光标跳转字符,实现范围删除    
                       d$ 删除到行尾
                       d0 删除到行首
复制命令         y 复制,行为相似于d命令
                        yy:复制行
                        #yy 复制多行
                        Y:复制整行
粘贴命令
                         p 缓冲区存的如果为整行,则粘贴当前光标所在行的下方;否则,则粘贴至当前光标所在处的后面
                         P 缓冲区存的如果为整行,则粘贴当前光标所在行的上方;否则,则粘贴至当前光标所在处的前面
cat 可以查看文本内容
nl  显示行号,相当于cat -b
tac 逆向显示文本内容
rev 将同一行的内容逆向显示
hexdump 查看非文本文件内容
more 可以实现分页查看文件,可以配合管道实现输出信息的分页
less 命令是man命令使用的分页器
head 可以显示文件或标准输入的前面行
tail 和head 相反,查看文件或标准输入的倒数行
cut 命令可以提取文本文件或STDIN数据的指定列    -d  指明分隔符     -c 按字符切割
paste 合并多个文件同行号的列到一行
分析文本的工具
        文本数据统计:wc
        整理文本:sort
        比较文件:diff和patch
sort  把整理过的文本显示在STDOUT,不改变原始文件uniq命令从输入中删除前后相接的重复的行        uniq常和sort 命令一起配合使用diff命令比较两个文件之间的区别 
基本正则表达式元字符
      .   匹配任意单个字符,可以是一个汉字
      []   匹配指定范围内的任意单个字符,示例:[wang]   [0-9]   [a-z]   [a-zA-Z]
      [^] 匹配指定范围外的任意单个字符,示例:[^wang]
      * 匹配前面的字符任意次,包括0次,贪婪模式:尽可能长的匹配
      .* 任意长度的任意字符
      \{n\} 匹配前面的字符n次
      \{m,n\} 匹配前面的字符至少m次,至多n次
      \{,n\} 匹配前面的字符至多n次,<=n
      \{n,\} 匹配前面的字符至少n次
      ^ 行首锚定,用于模式的最左侧
      $ 行尾锚定,用于模式的最右侧
      ^PATTERN$ 用于模式匹配整行
      ^$ 空行
      ^[[:space:]]*$   空白行
或者:\|
      a\|b #a或b  
      C\|cat #C或cat  
      \(C\|c\)at #Cat或cat
扩展正则表达式
      . 任意单个字符
      [wang] 指定范围的字符
      [^wang] 不在指定范围的字符
      [:alnum:] 字母和数字
      [:alpha:] 代表任何英文大小写字符,亦即 A-Z, a-z
      [:lower:] 小写字母,示例:[[:lower:]],相当于[a-z]
      *   匹配前面字符任意次
      ? 0或1次
      + 1次或多次
      {n} 匹配n次
      {m,n} 至少m,至多n次
      ^ 行首
      $ 行尾
       \<, \b 语首
       \>, \b 语尾
       () 分组
       后向引用:\1, \2, ...
       | 或者
       a|b #a或b
       C|cat #C或cat
       (C|c)at #Cat或cat
grep 命令主要对文本的(正则表达式)行基于模式进行过滤
        --color=auto 对匹配到的文本着色显示
        -m # 匹配#次后停止
        -v 显示不被pattern匹配到的行
        -i 忽略字符大小写
        -n 显示匹配的行号
        -c 统计匹配的行数
        -o 仅显示匹配到的字符串
        -q 静默模式,不输出任何信息
        -e 实现多个选项间的逻辑or关系,如:grep –e ‘cat ’ -e ‘dog’ fifile
        -w 匹配整个单词
        -E 使用ERE,相当于egrep
        -F 不支持正则表达式,相当于fgrep
        -f fifile 根据模式文件处理
        -r 递归目录,但不处理软链接
        -R 递归目录,但处理软链接
shell 脚本编程
三种处理逻辑
        顺序执行
        选择执行
        循环执行
格式要求:首行shebang机制        #!/bin/bash
               :给予执行权限,在命令行上指定脚本的绝对或相对路径
               :直接运行解释器,将脚本作为解释器程序的参数运行
总结:脚本错误常见的有三种
               语法错误,会导致后续的命令不继续执行,可以用bash -n 检查错误,提示的出错行数不一定是准
确的
               命令错误,后续的命令还会继续执行,用bash -n 无法检查出来 ,可以使用 bash -x 进行观察
               逻辑错误:只能使用 bash -x 进行观察
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!