Linux 学习笔记 04 —— 文件管理和磁盘管理相关命(2) 详解 grep 命令(1)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

which 命令用于查找并显示给定命令的绝对路径,环境变量 PATH 中保存了查找命令时需要遍历的目录。which 指令会在环境变量 $PATH 设置的目录里查找符合条件的文件。也就是说,使用 which 命令,就可以看到某个系统命令是否存在,以及执行的到底是哪一个位置的命令。

用法举例:

songyangji@SongyangJi-Ubuntu-DeskStop:~$ which ls

/usr/bin/ls

songyangji@SongyangJi-Ubuntu-DeskStop:~$ which which

/usr/bin/which

find


Linux下find命令在目录结构中搜索文件,并执行指定的操作。Linux下find命令提供了相当多的查找条件,功能很强大。

但是我们只需要掌握最常用的即可

  • 命令格式

find [路径] [选项] [参数]

命令参数:

pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。

-print: find命令将匹配的文件输出到标准输出。

-exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为’command’ { } ;,注意{ }和\;之间的空格。

-ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。

命令选项:

-name 按照文件名查找文件。

-perm 按照文件权限来查找文件。

-prune 使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略。

-user 按照文件属主来查找文件。

-group 按照文件所属的组来查找文件。

-mtime -n +n 按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。

-nogroup 查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。

-nouser 查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

-newer file1 ! file2 查找更改时间比文件file1新但比文件file2旧的文件。

-type 查找某一类型的文件,诸如:

b - 块设备文件。

d - 目录。

c - 字符设备文件。

p - 管道文件。

l - 符号链接文件。

f - 普通文件。

-size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。-depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。

-fstype:查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。

-mount:在查找文件时不跨越文件系统mount点。

-follow:如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

-cpio:对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

另外,下面三个的区别:

-amin n 查找系统中最后N分钟访问的文件

-atime n 查找系统中最后n*24小时访问的文件

-cmin n 查找系统中最后N分钟被改变文件状态的文件

-ctime n 查找系统中最后n*24小时被改变文件状态的文件

-mmin n 查找系统中最后N分钟被改变文件数据的文件

-mtime n 查找系统中最后n*24小时被改变文件数据的文件

  • 用法举例

在/home目录下查找以.txt结尾的文件名

[deng@localhost test]$ find /home -name “*.txt”

/home/deng/.cache/tracker/db-version.txt

/home/deng/.cache/tracker/db-locale.txt

/home/deng/.cache/tracker/parser-sha1.txt

/home/deng/.cache/tracker/locale-for-miner-user-guides.txt

/home/deng/.cache/tracker/locale-for-miner-apps.txt

匹配文件路径或者文件

find /usr -path “*local”

找出当前目录下不是以.txt结尾的文件

find ./ ! -name “*.txt”

根据文件大小来搜索

搜索大于10KB的文件

find / -type f -size +10k

搜索小于10KB的文件

find / -type f -size -10k

搜索等于10KB的文件

find / -type f -size 10k

删除当前目录下所有.txt文件

find ./ -type f -name “*.txt” -delete

grep


Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

grep命令的选项用于对搜索过程的补充,而其命令的模式十分灵活,可以是变量字符串正则表达式。需要注意的是:一当模式中包含了空格,务必要用双引号将其引起来。

linux系统支持三种形式的grep命令,大儿子就是grep,标准,模仿的代表。二儿子兴趣爱好多-egrep,简称扩展grep命令,其实和grep -E等价,支持基本和扩展的正则表达式。小儿子跑的最快-fgrep,简称快速grep命令,其实和grep -F等价,不支持正则表达式,按照字符串表面意思进行匹配。

  • 命令用法

用法: grep [选项]… 模式 [文件]…

grep [options] PATTERN [FILE…]

grep [options] [-e PATTERN | -f FILE] [FILE…]

在每个<文件>中查找给定<模式>。

例如:grep -i ‘hello world’ menu.h main.c

<模式>可以包括多个模式字符串,使用换行符进行分隔。

模式选择与解释:

-E, --extended-regexp <模式> 是扩展正则表达式

-F, --fixed-strings <模式> 是字符串

-G, --basic-regexp <模式> 是基本正则表达式

-P, --perl-regexp <模式> 是 Perl 正则表达式

-e, --regexp=<模式> 用指定的<模式>字符串来进行匹配操作

-f, --file=<文件> 从给定<文件>中取得<模式>

-i, --ignore-case 在模式和数据中忽略大小写

–no-ignore-case 不要忽略大小写(默认)

-w, --word-regexp 强制<模式>仅完全匹配字词

-x, --line-regexp 强制<模式>仅完全匹配整行

-z, --null-data 数据行以一个 0 字节结束,而非换行符

杂项:

-s, --no-messages 不显示错误信息

-v, --invert-match 选中不匹配的行

-V, --version 显示版本信息并退出

–help 显示此帮助并退出

输出控制:

-m, --max-count=<次数> 得到给定<次数>次匹配后停止

-b, --byte-offset 输出的同时打印字节偏移

-n, --line-number 输出的同时打印行号

–line-buffered 每行输出后刷新输出缓冲区

-H, --with-filename 为输出行打印文件名

-h, --no-filename 输出时不显示文件名前缀

–label=<标签> 将给定<标签>作为标准输入文件名前缀

-o, --only-matching 只显示行中非空匹配部分

-q, --quiet, --silent 不显示所有常规输出

–binary-files=TYPE 设定二进制文件的 TYPE(类型);

TYPE 可以是 ‘binary’、‘text’ 或 ‘without-match’

-a, --text 等同于 --binary-files=text

-I 等同于 --binary-files=without-match

-d, --directories=ACTION 读取目录的方式;

ACTION 可以是read, recurse,或skip

-D, --devices=ACTION 读取设备、先入先出队列、套接字的方式;

ACTION 可以是read或skip

-r, --recursive 等同于–directories=recurse

-R, --dereference-recursive 同上,但遍历所有符号链接

–include=GLOB 只查找匹配 GLOB(文件模式)的文件

–exclude=GLOB 跳过匹配 GLOB 的文件

–exclude-from=FILE 跳过所有匹配给定文件内容中任意模式的文件

–exclude-dir=GLOB 跳过所有匹配 GLOB 的目录

-L, --files-without-match 只打印没有匹配上的<文件>的名称

-l, --files-with-matches 只打印有匹配的<文件>的名称

-c, --count 只打印每个<文件>中的匹配行数目

-T, --initial-tab 行首制表符对齐(如有必要)

-Z, --null 在<文件>名最后打印空字符

文件控制:

-B, --before-context=NUM 打印文本及其前面NUM 行

-A, --after-context=NUM 打印文本及其后面NUM 行

-C, --context=NUM 打印NUM 行输出文本

-NUM 等同于 --context=NUM

–color[=WHEN],

–colour[=WHEN] 使用标记高亮匹配字串;

WHEN 可以是“always”、“never”或“auto”

-U, --binary 不要清除行尾的 CR 字符(MSDOS/Windows)

  • 关于正则表达式

规则表达式:

grep的规则表达式:

^ #锚定行的开始 如:'^grep’匹配所有以grep开头的行。

$ #锚定行的结束 如:'grep$'匹配所有以grep结尾的行。

. #匹配一个非换行符的字符 如:'gr.p’匹配gr后接一个任意字符,然后是p。

  • #匹配零个或多个先前字符 如:'*grep’匹配所有一个或多个空格后紧跟grep的行。

.* #一起用代表任意字符。

[] #匹配一个指定范围内的字符,如’[Gg]rep’匹配Grep和grep。

[^] #匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep’匹配不包含A-F和H-Z的一个字母开头,紧跟rep的行。

(…) #标记匹配字符,如’(love)',love被标记为1。

< #锚定单词的开始,如:'<grep’匹配包含以grep开头的单词的行。

> #锚定单词的结束,如’grep>'匹配包含以grep结尾的单词的行。

x{m} #重复字符x,m次,如:'0{5}'匹配包含5个o的行。

x{m,} #重复字符x,至少m次,如:'o{5,}'匹配至少有5个o的行。

x{m,n} #重复字符x,至少m次,不多于n次,如:'o{5,10}'匹配5–10个o的行。

\w #匹配文字和数字字符,也就是[A-Za-z0-9],如:'G\w*p’匹配以G后跟零个或多个文字或数字字符,然后是p。

\W #\w的反置形式,匹配一个或多个非单词字符,如点号句号等。

\b #单词锁定符,如: '\bgrep\b’只匹配grep。

POSIX字符:

为了在不同国家的字符编码中保持一至,POSIX(The Portable Operating System Interface)增加了特殊的字符类,如[:alnum:]是[A-Za-z0-9]的另一个写法。要把它们放到[]号内才能成为正则表达式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符类。

使用举例

  1. 文件中(模糊)搜索包含一个单词的行

注意,是搜索文件内的内容,而且不是完全匹配才显示(可以使用 -w参数)

[deng@localhost share]$ grep “root” /etc/passwd

root❌0:0:root:/root:/bin/bash

operator❌11:0:operator:/root:/sbin/nologin

[deng@localhost share]$

  1. 多文件也是可以的

[deng@localhost test]$ grep “root” passwd passwd1

passwd:root❌0:0:root:/root:/bin/bash

passwd:operator❌11:0:operator:/root:/sbin/nologin

passwd1:root❌0:0:root:/root:/bin/bash

passwd1:operator❌11:0:operator:/root:/sbin/nologin

[deng@localhost test]$

  1. 输出除匹配之外的所有行(-v

[deng@localhost test]$ grep -v “root” /etc/passwd

  1. 只输出文件中匹配到的部分(-o

[deng@localhost test]$ grep -o “root” /etc/passwd

root

root

root

root

  1. 使用正则表达式

[deng@localhost test]$ grep -E “[1-9]” /etc/passwd

或者

[deng@localhost test]$ egrep “[1-9]” /etc/passwd

  1. 统计文件或者文本中包含匹配字符串的行数 (-c)

[deng@localhost test]$ grep -c “root” /etc/passwd

2

  1. 输出包含匹配字符串的行号(-n

[deng@localhost test]$ grep -n “root” /etc/passwd

1:root❌0:0:root:/root:/bin/bash

10:operator❌11:0:operator:/root:/sbin/nologin

[deng@localhost test]$

  1. 搜索多个文件并输出(-l)查找匹配的文本文件的文件名(或者显示不匹配的文件名-L

songyangji@SongyangJi-Ubuntu-DeskStop:~$ grep -l “h” test.txt test2.txt

test.txt

结语

小编也是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。

我们选择的这个行业就一直要持续的学习,又很吃青春饭。

虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。

送给每一位想学习Java小伙伴,用来提升自己。

在这里插入图片描述

本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
untu-DeskStop:~$ grep -l “h” test.txt test2.txt

test.txt

结语

小编也是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。

我们选择的这个行业就一直要持续的学习,又很吃青春饭。

虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。

送给每一位想学习Java小伙伴,用来提升自己。

[外链图片转存中…(img-FV287cQ3-1713563120031)]

本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-TIM7b7Qa-1713563120031)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值