先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024b (备注运维)
正文
所谓的正则表达式我个人理解就是正规的表示方法。他是用简单的方法来实现强大的功能,所以深受计算机爱好者的使用。
三剑客与正则表达式是什么关系呢?
我们可以这样理解,三剑客就是普通的命令,有的把他们叫做工具,在我看来都一样。而正则表达式就好比一个模版。三剑客能读懂这个模版。就这么简单。注意只有三剑客才能读懂这个模版哦!
现在他们的关系和功能都搞懂了,接下来我们就来认识下他们怎么结合的。正则表达式是一个模版,这个模版是由一些普通字符和一些元字符组成。普通字符包括大小写的字母和数字,而元字符则具有特殊的含义。具体如下
元字符 | 功能 | 意思 |
^ | 匹配行首 | 表示以某个字符开头 |
$ | 匹配行尾 | 表示以某个字符结尾 |
^$ | 空行的意思 | 表示空行的意思 |
. | 匹配任意单个字符 | 表示任意一个字符 |
* | 字符***匹配0****或多个此字符** | 表示重复的任意多个字符 |
** | 屏蔽一个元字符的特殊含义 | 表示去掉有意义的元字符的含义 |
[] | 匹配中括号内的字符 | 表示过滤括号内的字符 |
.* | 代表任意多个字符 | 就是代表任意多个字符 |
lele{n} | 用来匹配前面lele出现次数。n为次数 | 就是统计前面lele出现的次数 |
lele{n,} | 含义同上,但次数最少为****n | 从功能就可以看出 |
lele{n,m} | 义同上,但lele出现次数在n与m之间 | 从功能也可以看出 |
lele{n,m} | 义同上,但lele出现次数在n与m之间 | 从功能也可以看出 |
三剑客的功能非常强大,但我们只需要掌握他们分别擅长的领域即可:grep****擅长查找功能,sed擅长取行和替换。awk擅长取列。
二、grep
文本过滤(模式:pattern)工具,grep, egrep
grep [OPTIONS] PATTERN [FILE...]
--color=auto
对匹配到的文本着色显示-v
显示不被pattern匹配到的行-i
忽略字符大小写-n
显示匹配的行号-c
统计匹配的行数-o
仅显示匹配到的字符串-q
静默模式,不输出任何信息-A #
after, 后#行-B #
before, 前#行-C #
context, 前后各#行-e
实现多个选项间的逻辑or关系
grep –e ‘cat ’ -e ‘dog’ file
-w
匹配整个单词-E
使用ERE,相当于egrep-F
相当于fgrep,不支持正则表达式
举例子:
1、查找文件内容包含root的行数
2、查找文件内容不包含root的行
3、查找以s开头的行
4、查找以n结尾的行
三、sed
sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循环。如果没有使诸如‘D’ 的特殊命令,那会在两个循环之间清空模式空间,但不会清空保留空间。这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。
sed [option]... 'script' inputfile
- 选项
-n
不输出模式空间内容到屏幕,即不自动打印-e
多点编辑-f
/PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本-r
支持使用扩展正则表达式- -i 直接编辑文件
-i.bak
备份文件并原处编辑
- script 地址定界
- 不给地址:对全文进行处理
- 单地址:
#
: 指定的行,$:最后一行
/pattern/
:被此处模式所能够匹配到的每一行 - 地址范围:
#,#
#,+#
/pat1/,/pat2/
`#,/pat1/ - ~:步进
1~2 奇数行
2~2 偶数行
- 编辑命令:
d
删除模式空间匹配的行,并立即启用下一轮循环p
打印当前模式空间内容,追加到默认输出之后a [\]text1
在指定行后面追加文本,支持使用\n实现多行追加i [\]text
在行前面插入文本c [\]text
替换行为单行或多行文本w /path/somefile
保存模式匹配的行至指定文件r /path/somefile
读取指定文件的文本至模式空间中匹配到的行后=
为模式空间中的行打印行号!
模式空间中匹配行取反处理- s///:查找替换,支持使用其它分隔符,s@@@,s###
替换标记:g
行内全局替换p
显示替换成功的行w /PATH/TO/SOMEFILE
将替换成功的行保存至文件中
举例子:
1、打印出文件第二行
2、打印出2-5行的内容
3、将文件中的root全部替换为abc
直接修改读取的文件内容,而不是输出到终端。
s :取代,可以直接进行取代的工作。
g: 是全局的意思。其中#是格式符,他也可以是@或者别的/。
Sed替换格式是:sed -i ‘s/要替换的内容/替换成的内容/g’ 文件名。
四、awk
报告生成器,格式化文本输出,有多种版本:New awk(nawk),GNU awk( gawk)
awk [options] 'program' file…
- program:pattern{action statements;…}
- pattern部分决定动作语句何时触发及触发事件
BEGIN,END - action statements对数据进行处理,放在{}内指明
print, printf
- pattern部分决定动作语句何时触发及触发事件
最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:
给大家整理的电子书资料:
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注运维)
[外链图片转存中…(img-ZueSmdrp-1713358175967)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!