03 grep&vim&find

1、定义一个对所有用户都生效的命令别名,比如lftps='lftp 172.168.0.1/pub'

  ]~#nano  /etc/bashrc
    编辑/etc/bashrc文件,最后一行添加
    alias cl="clear"
    ^O写入,回车保存,^X退出编辑。
    退出当前shell,重新登录,输入 alias命令,查看 alias 变量中有无cl命名的变量,以及使用 cl 命令进行清屏操作。

2、显示/etc/passwd文件中不以/bin/bash结尾的行

grep 查找,使用^限定为行首内容,使用$限定行尾内容;

  ]~# grep "/bin/bash$" /etc/passwd    显示以/bin/bash结尾的行
  ]~# grep -v  "/bin/bash$"  /etc/passwd     通过-v 选项进行取反,显示不以/bin/bash结尾的行

3、找出/etc/passwd文件中,包含二位数字或者三位数的行

这个问题主要考查以下内容,1、数字如何表示,2、重复出现的次数如何表示,2、词的限定如何表示,为了看得明白一些,使用扩展正则表达式。
1)、数字的表示 [:digit:] 或 0-9, 那么用 [[:digit:]] 或 [0-9] 表示任意单个数字;这个基本正则与扩展正则无差异;
2)、重复,通过 {m} 表示重复 m 次,通过{m,n} 表示重复 m - n 这个区间的次数。在使用基本正则时需要在 { 和 } 前面加上转义字符 \ , 表达式如 {m,n} ;
3)、词首限定 \<,词尾限定 \>,这点基本正则与扩展正则在使用上无差异。

  ]~# grep -E  "\<[0-9]{2,3}\>" /etc/passwd

4、显示/proc/meminfo文件中以大写或者小写S开头的行;用三种方式实现。

这里主要从三个知识点出发,1、[]表示方括号内的任意单个字符,2、grep 选项中 -i 表示忽略大小写差异, 3、扩展正则表达式 通过 | 符号 表示或。

  ]~# grep "^[sS]"   /proc/meminfo
  ]~# grep   -i   "^[s]"   /proc/meminfo
  ]~# grep   -E  "^(s|S)"   /proc/meminfo
grep /proc/meminfo示例

5、使用echo输出一个绝对路径,使用egrep取出路径名,类似执行 dirname /etc/passwd的结果

这里使用/etc/rc.d/init.d/functions/ ,对于末尾有/ 的字符串,采取二次过滤的方法。首先 grep使用-o选项过滤掉末尾/,然后再通过管道输出给 grep 进行第二次过滤,选择以/结尾的部分。

  ]~# echo /etc/rc.d/init.d/functions/ | grep -Eo ".*[^/]+" | grep -Eo ".*[/]+"
egrep 二次过滤

6、找出 ifconfig 中的 ip 地址。要求结果中只显示 IP 地址。

IPv4 地址的特征是4段数字,且用.号分隔开,前三段内容数字组用[0-9]{1,3}表示,[.]表示中间的分隔符,然后用()符号把这个模式包住表示特征范围,后接{3}表示重复三次,因为共有三段类似,最后再跟[0-9]{1,3}表示最后一段数字。
[[:space:]]表示空白符号,至netmask,用grep -o 选项只输出符合特征的这一段
cut命令,选项 -d 用空格作为分隔符表示为' ',-f 选择 输出第几段。

  ]~# ifconfig | grep -E  -o "([0-9]{1,3}[\.]){3}[0-9]{1,3}[[:space:]]*netmask"|cut -d ' ' -f 1 
grep 只显示 ip 地址

7、vim 定制自动缩进四个字符

vim 永久有效的设定,全局定制在/etc/vimrc文件中编辑,个人定制在~/.vimrc,.vimrc文件有可能不存在,需要创建。在末行模式下的设定,仅对当前vim 进程有效。
获取帮助:
:help
:help subject
查看 set 详细的选项,可以通过末行模式输入:help set进行查看。

  ]~# nano ~/.vimrc
    设置自动缩进,添加一行set autoindent,
    设置tab 缩进4个字符,添加一行内容set tabstop=4,或者简写为set ts=4,保存退出。
  ]~# 打开vim 编辑器,验证 tab 键是否是缩进4个字符。

8、编写脚本,实现自动添加三个用户,并计算这三个用户的 uid 之和。

算术运算格式有以下四种类型:
(1) let VAR=算术运算表达式
(2) VAR=$[算术运算表达式]
(3) VAR=$((算术运算表达式))
(4) VAR=$(expr $ARG1 $OP $ARG2)

思路:通过useradd添加用户,使用grep 和 cut 得到用户的uid,使用算术运算符进行 uid 求和运算。
首先对于命令结果的引用使用$(COMMAND),将命令$(grep "^" /etc/passwd | cut -d: -f 3)的结果赋值给变量,然后进行算术运算式求和操作。
编辑/tmp/adduser.sh文件,添加内容如下,保存退出。给此文件添加执行权限后执行脚本。

  1 #!/bin/bash
  2
  3 useradd user14
  4 useradd user15
  5 useradd user16
  6
  7 var1=$(grep "^\" /etc/passwd | cut -d: -f 3)
  8 var2=$(grep "^\" /etc/passwd | cut -d: -f 3)
  9 var3=$(grep "^\" /etc/passwd | cut -d: -f 3)
 10
 11 echo $[$var1+$var2+$var3]
  ]~# chmod +x /tmp/adduser.sh
  ]~# /tmp/adduser.sh
adduser.sh 脚本内容

运行结果及验证

9、find 用法以及常用用法的实例演示。

linux 系统上查找,可以使用locate和find两个命令。locate 是通过数据库索引进行key-value查找,有滞后性、模糊性,但速度快。find是类似全文查找,有实时性、精确性,但速度略慢。
find 的用法 :find [ OPTIONS ] [ 查找起始路径 ] [ 查找条件 ] [ 处理动作 ]
  查找起始路径:指定具体搜索目标启示路径,默认是当前目录;
  查找条件:指定的查找标准,可以根据文件名,大小,类型,从属关系,权限等;默认各个条件之间是用-a选项进行连接;如果是或,使用-o选项进行连接;如果是取反,使用-not选项进行连接。
    - 根据文件名
      -name "pattern" 区分大小写
      -iname "pattern" 不区分大小写
        以上两个条件支持glob风格的通配符: , ?, [], [^]
      -regex pattern 基于正则表达式模式查找文件,匹配整个路径,而非其名;
    - 根据文件大小
      -size [+|-] #UNIT,常用单位 k, M, G
    - 根据文件时间戳
      以“天”为单位
        -atime,-ctime, -mtime [+|-] # #表示数字
      以“分钟”为单位
        -amin, -mmin, -cmin [+|-] # #表示数字
    - 根据文件类型
      -type TYPE:
        f:普通文件;d:目录文件; l:符号链接文件;b: 块设备文件; c:字符设备文件; p: 管道文件;s: 套接字文件;
    - 根据文件从属
      -user USERNAME:查找属主指定用户的所有文件;
      -group GRPNAME:查找属组指定组的所有文件;
      -uid UID:查找指定UID的所有文件;
      -gid GID:查找指定 GID 的所有文件;
      -nouser:查找没有属主的文件;
      -nogroup:查找没有属组的文件;
    - 根据文件权限
      -perm [/|-] mode
        mode:前面不加任何符号,表示精确权限匹配;
        /mode:表示任一类用户(u,g,o)的权限中的任一位(r,w,x)符合条件即满足;
        -mode:表示每一类用户(u,g,o)的权限中的每一位(r,w,x)同时符合条件即满足;
  标准动作:默认为找出指定路径下的所有文件;
  处理动作:对符合查找条件的文件做出的操作,例如删除等操作;默认为输出至标准输出;
    - -print 默认处理动作,输出至标准输出;
    - -ls,类似对查找到的文件执行 "ls -l " 命令,输出文件的详细信息;
    - -delete,删除查找到的文件;
    - -fls /PATH/TO/SOMEFILE,把查找到的所有文件的长格式信息保存至指定文件中;
    - ok COMMAND {} ; ,对查找到的每个文件执行由COMMAND表示的命令,每个文件操作都由客户进行确认;
    - exec COMMAND {} ; ,对查找到的每个文件执行由COMMAND表示的命令,无需一一确认;
    *
*注意:find 传递查找到的文件路径至后面的命令时,是先查找出所有符合条件的文件路径,并一次性传递给后面的命令;但有些命令不能接受过长的参数,此时命令执行会失败;另一种方式可规避此问题:find | xargs COMMAND
例题:
1)、查找/etc目录下所有用户都没有写权限的文件;

  ~]# find /etc -perm /222 -type f    #首先查找/etc目录下任何用户、用户组、其他组有写权限的文件,
  ~]# find /etc/ -not -perm /222 -type f #然后用-not选项进行取反,那么取得的就是都没有写权限的文件

2)、查找当前系统上没有属主或属组,且最近一周内曾被访问过的文件或目录;

  ~]# find /   -atime -7  \( -nouser -o -nogroup \)   -ls 
  -atime -7 表示一周以内, -nouser 表示没有属主, -nogroup 表示没有属组    -o 表示或

你可能感兴趣的:(03 grep&vim&find)