VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
  • Linux文件查找命令find与三剑客之grep

一、find#

根据文件的名称或者属性查找文件。

语法格式:

	find   [查找范围]  [参数]



参数:

	-name : 按照文件的名字查找文件

		* :通配符

	-iname :  按照文件的名字查找文件(忽略大小写)

	-size : 按照文件的大小查询文件

		+	: 大于

		-	: 小于

		没符号 : 等于



	-mtime : 按照修改时间去查询

		+(可以省略) : n 天以前

		- 			: n 天以内

	-atime :按照访问时间去查询(参数同上)

	-ctime :按照更改时间去查询(参数同上)



	-user :按照用户的属主查询

	-group : 按照用户的属组查询

	-type : 按照文件的类型查询

		d : 文件夹

		l : 链接文件

		s : 套接字文件

		p : 管道文件

		c : 字符文件

		b :磁盘文件

		f : 普通文件



	-perm : 按照文件的权限查询

	-inum : 根据index node号码查询



	-a : 并且(可以省略,默认时并且)

	-o : 或者

	-maxdepth : 查询的目录深度(必须放置与第一个参数位) 



	-exec : 将find处理好的结果交给其他命令继续处理。

案例演示:

	案例1:查询/etc目录下hosts文件

        [root@localhost ~]# find /etc/ -name '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`

知识储备:

dd : 生成文件

	if 		:从什么地方读

	of 		: 写入到什么文件

	bs 		: 每次写入多少内容

	count 	: 写入多少次

	

| : 前面一个命令的结果交给后面一个命令处理

xargs : 把处理的文本变成以空格分割的一行

`` : 提前执行命令,然后将结果交给其他命令来处理

二、grep#

grep是Linux三剑客之一,是一种文本过滤器(根据文本内容过滤文件)。

Linux中grep经常搭配正则表达式一起使用,所以关于正则相关的知识请查看笔者之前的博客,里面有详细的介绍,这里就不再过多介绍了。

语法格式:

	grep [参数] [匹配规则] [操作对象]



参数:

	-n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来

	-A : 匹配成功之后,将匹配行的后n行显示出来

	-B : 匹配成功之后,将匹配行的前n行显示出来

	-C : 匹配成功之后,将匹配行的前后各n行显示出来

	-c :  只显示匹配成功的行数

	-o :  只显示匹配成功的内容

	-v :  反向过滤

	-q :  静默输出

	-i : 忽略大小写

	-l :  匹配成功之后,将文本的名称打印出来

	-R|-r : 递归匹配 



	-E : 使用拓展正则表达式   等价于  egrep



需要使用拓展正则的相关符号:

	{}     :匹配的次数

		{n}		: 匹配n次

		{n,}	:至少匹配n次

		{n,m}	:匹配 n 到 m 次

		{,m}	:最多匹配m次

	+      :匹配至少有一个前导字符

	?      : 匹配一个或零个前导字符

	|      :或

知识储备:

知识储备:

	$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败。

	wc :  匹配行数

		-l : 打印匹配行数

		-c : 打印匹配的字节数

	



eg:在/etc目录下,有多少个文件包含root。

	grep -rl 'root' /etc/ | wc -l

搭配正则表达式相关案例演示:

案例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
 
出处:https://www.cnblogs.com/JZjuechen/p/15713316.html


相关教程