find+grep+正则表达式

1、find

根据文件的名称或者属性查找文件。
# 自己在 /root/adc目录下长剑一个文件 touch nginx.conf,里面内容随便编写,便于举例。
语法格式:
find [查找范围] [参数] 参数:
-name : 按照文件的名字查找文件 [root@linux ~]# find /root/adc -name nginx.conf
* :通配符 [root@linux ~]# find /root/adc -name nginx.*
-iname : 按照文件的名字查找文件(忽略大小写) [root@linux ~]# find /root/adc -iname Nginx.c*
-size : 按照文件的大小查询文件
+ : 大于 [root@linux ~]# find /root/adc -size +5k
- : 小于 [root@linux ~]# find /root/adc -size -5M
没符号 : 等于 [root@linux ~]# find /root/adc -size 23k 文件的时间属性通过 stat 指令查看
-mtime : 按照修改时间去查询(modify修改时间)
+(可以省略) : n 天以前 [root@linux ~]# find adc/nginx.conf -mtime 0
- : n 天以内 [root@linux ~]# find adc/nginx.conf -mtime -1
-atime 同上(Access访问时间)
-ctime 同上(Change改变时间) -user :按照用户的属主查询 [root@linux ~]# find adc/ -user root
-group : 按照用户的属组查询 [root@linux ~]# find adc/ -group root
-type : 按照文件的类型查询 [root@linux ~]# find adc/ -type f
d : 文件夹
l : 链接文件
s : 套接字文件
p : 管道文件
c : 字符文件
b :磁盘文件
f : 普通文件 -perm : 按照文件的权限查询 [root@linux ~]# find adc/ -perm 644
-inum : 根据index node号码查询(ll -ih) [root@linux ~]# ll -ih adc/
i : 显示inode号码
h : 显示文件大小 -a : 并且(可以省略,默认时并且) [root@linux ~]# find adc/ -user root -a -type f
-o : 或者 [root@linux ~]# find adc/ -user root -o -type f
-maxdepth : 查询的目录深度(必须放置于第一个参数位)
查询当前第0层目录 [root@linux ~]# find adc/ -maxdepth 0 >>> adc/
查询第1层目录内容 [root@linux ~]# find adc/ -maxdepth 1 >>> adc/nginx.conf
-exec : 将find处理好的结果交给其他命令(不是find的其他指令)继续处理。 知识储备:
dd : 生成文件
if :从什么地方读
of : 写入到什么文件
bs : 每次写入多少内容
count : 写入多少次
例如:
[root@linux ~]# dd if=/dev/zero of=666.txt bs=200k count=100
100+0 records in
100+0 records out
20480000 bytes (20 MB) copied, 0.159963 s, 128 MB/s 案例:
案例1:查询/etc目录下hosts文件
[root@localhost ~]# find /etc/ -name 'hosts'
/etc/hosts
案例2:查询/etc目录下名称中包含hosts文件
[root@localhost ~]# find /etc/ -name '*hosts*' 案例3:要求把/etc目录下,所有的普通文件打包压缩到/tmp目录
[root@localhost /tmp]# tar -czPf /tmp/etcv2.tar.gz `find /etc/ -type f | xargs`
eg:[root@linux ~]# tar -czPf adc/DSB.tar.gz `find adc/ -type f | xargs`
'''必须这样的格式顺序,如果``在前面就不行,会报错。 知识储备
管道符 | : 前面一个命令的结果交给后面一个命令处理
xargs : 把处理的文本变成以空格分割的一行
`` : 提前执行命令,然后将结果交给其他命令来处理

2、grep

linux三剑客之一,文本过滤器(根据文本内容过滤文件)。

语法格式:
grep [参数] [匹配规则] [操作对象] 参数:
-n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来 [root@linux ~]# grep -n hello adc/nginx.conf
-A : 匹配成功之后,将匹配行的后n行显示出来 [root@linux ~]# grep -C3 hello adc/nginx.conf
-B : 匹配成功之后,将匹配行的前n行显示出来
-C : 匹配成功之后,将匹配行的前后各n行显示出来
-c : 只显示匹配成功的行数
-o : 只显示匹配成功的内容
-v : 反向过滤 [root@linux ~]# grep -v under adc/nginx.conf
-q : 静默输出
-i : 忽略大小写 [root@linux ~]# grep -i unDEr adc/nginx.conf
-l : 匹配成功之后,将文本的名称打印出来 [root@linux ~]# grep -l under adc/nginx.conf
-R|-r : 递归匹配 [root@linux ~]# grep -r y adc/nginx.conf -E : 使用拓展正则 等价于 egrep 知识储备:
$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。
[root@linux ~]# grep -C3 under adc/nginx.conf | echo $? wc : 匹配行数
-l : 打印匹配行数
-c : 打印匹配的字节数 在/etc目录下,有多少个文件包含root。
grep -rl 'root' /etc/ | wc -l

3、正则表达式

1、正则表达式的分类(grep)
1、普通正则表达式
2、拓展正则表达式 2、普通正则表达式 ^ : 以某字符开头
$ : 以某字符结尾
. : 匹配除换行符之外的任意单个字符
* :匹配前导字符的任意个数
[] : 某组字符串的任意一个字符
[^] : 取反
[a-z] : 匹配小写字母
[A-Z] : 匹配大写字母
[a-zA-Z] : 匹配字母
[0-9] : 匹配数字
\ : 取消转义
() : 分组
\n : 代表第n个分组 3、拓展正则
{} :匹配的次数
{n} : 匹配n次
{n,} :至少匹配n次
{n,m} :匹配 n 到 m 次
{,m} :最多匹配m次
+ :匹配至少有一个前导字符
? : 匹配一个或零个前导字符
| :或 案例:
案例1:在/etc/passwd文件中,匹配以ftp开头的行
grep '^ftp' /etc/passwd 案例2:在/etc/passwd文件中,匹配以bash结尾的行
grep 'bash$' /etc/passwd 案例3:匹配本机中有哪些ip
ip a | grep -oE '([0-9]{1,3}\.){3}[0-9]{1,3}' 案例4:要求将/etc/fstab中的去掉包含 # 开头的行,且要求 # 后至少有一个空格
grep -vE '^#\ +' /etc/fstab 案例5:找出文件中至少有一个空格的行
grep -E '\ +' xxx 案例6:将 nginx.conf 文件中以#开头的行和空行,全部删除
grep -vE '^\ *#|^$' /etc/nginx/nginx.conf

find+grep+正则表达式的更多相关文章

  1. (转)linux grep 正则表达式

    转自:http://www.cnblogs.com/xiaouisme/archive/2012/11/09/2762543.html -------------------------------- ...

  2. linux grep 正则表达式

    grep正则表达式元字符集: ^ 锚定行的开始 如:'^grep'匹配所有以grep开头的行. $ 锚定行的结束 如:'grep$'匹配所有以grep结尾的行. . 匹配一个非换行符的字符 如:'gr ...

  3. LINUX中,find结合grep正则表达式,快速查找代码文件。

    ###目的###LINUX中,find结合grep正则表达式快速查找代码. 例如经常有需求:查找当前目录下所有.h文件中,"public开头,中间任意字符,以VideoFrameReceiv ...

  4. grep 正则表达式用引号括起来和元字符加反斜杠转义的测试

    grep 正则表达式用引号括起来和元字符加反斜杠转义的测试 实验在 grep 命令中的表达式:不加引号,加单引号,加双引号的区别,以及部分元字符前加与不加 `\’ 进行转义的区别.实验环境为“实验楼( ...

  5. grep 正则表达式

    本文转自:http://www.jb51.net/article/31207.htm 正则表达式只是一种表示法,只要工具支持这种表示法, 那么该工具就可以处理正则表达式的字符串.vim.grep.aw ...

  6. Linux 命令——grep | 正则表达式

    感觉讲的很详细,瞬间懂了grep,正则. from: here 简介 grep (global search regular expression(RE) and print out the line ...

  7. vim 和grep 正则表达式相似和区别

    正则表达式由两种基本字符类型组成:原义(正常)文本字符和元字符.元字符使正则表达式具有处理能力.所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符 ...

  8. grep&正则表达式

    p.MsoNormal,li.MsoNormal,div.MsoNormal { margin: 0cm; margin-bottom: .0001pt; text-align: justify; f ...

  9. 文本处理三剑客之grep&正则表达式

    grep是一个文本过滤工具,它支持正则表达式,能把搜索匹配到的行打印出来.grep的全称是Global Regular Expression Print(全局正则表达式)使用权限是所有用户. 一.gr ...

随机推荐

  1. Java 单引号 与 双引号 区别

    双引号,用来引用字符串, 单引号用来表示单个字符.

  2. jsp使用${}语法,对应的spring后台使用Model

    实现的前提,一定要在jsp文件顶部加上 <%@page isELIgnored="false" %> 如上图${aa}与${bb},是直接使用Model的key值对应的 ...

  3. Go语言系列之包

    Go语言的包(package) 一.包介绍 包(package)是多个Go源码的集合,是一种高级的代码复用方案,Go语言为我们提供了很多内置包,如fmt.os.io等. 二.定义包 我们还可以根据自己 ...

  4. Flowable实战(三)流程部署管理

    一.流程定义的版本   当部署流程定义时,数据库中的流程定义会是这个样子: id key name version myProcess:1:676 myProcess My important pro ...

  5. JAVA自定义连接池原理设计(一)

    一,概述 本人认为在开发过程中,需要挑战更高的阶段和更优的代码,虽然在真正开发工作中,代码质量和按时交付项目功能相比总是无足轻重.但是个人认为开发是一条任重而道远的路.现在本人在网上找到一个自定义连接 ...

  6. linux下玩转磁盘管理与挂载硬盘

    前言 本文将带来linux下的磁盘管理中的硬盘挂载,Linux操作系统挂载硬盘需要了解的一些知识.这可能是迄今为止介绍的最最最实用的linux硬盘挂载的文章了,比较详细.由于工作原因,平时使用的比较多 ...

  7. idea同时启动多个微服务模块进行管理

    1,打开IDEA项目中的 .idea 下 的workspace.xml 找到文件中的 RunDashboard 配置块,增加如下圈起来的地方 代码: <option name="con ...

  8. linux 查看端口占用情况并关闭进程

    首先要搞清楚 linux 查看进程和查看端口是两个概念,一般来讲进程会有多个,而固定端口只会有一个. 1.查看进程 ,通常在使用 ps   命令后 用管道连接(ps -ef|grep  xxx ) 查 ...

  9. 创建app子应用,配置数据库,编写模型,进行数据迁移

    文章目录 web开发django模型 1.创建app子应用 2.配置子应用 3.使用 4.配置子应用管理自已的路由 django数据库开发思维与ORM 1.创建数据库 2.配置数据库 3.安装pymy ...

  10. 学习AJAX必知必会(4)~JQuery发送Ajax请求

    一.JQuery发送Ajax请求 ■ 对于get和post请求,jQuery内部封装了Ajax请求的4个步骤和数据格式的设置 ■ 对于Ajax通用请求,jQuery内部封装了Ajax请求的4个步骤和数 ...