Shell函数和正则表达式
1. shell函数
shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数。给这段代码起个名字称为函数名,后续可以直接调用该段代码。
格式:
func() { #指定函数名
command #函数体
}
Shell 函数很简单,函数名后跟双括号,再跟双大括号。通过函数名直接调用,不加小括号。
#显示文本颜色
[root@localhost ~]# vim test.sh
#!/bin/bash
fun (){
for i in {..}
do
echo -e "\033[${i}mHello World\033[0m"
done
}
fun
:wq
[root@localhost ~]# bash test.sh
Hello World
Hello World
Hello World
Hello World
Hello World
Hello World
……
#函数返回值
[root@localhost ~]# vim test1.sh
#!/bin/bash
fun () {
echo ""
return
echo ""
}
fun
[root@localhost ~]# bash test1.sh #return 在函数中定义状态返回值,返回并终止函数,但返回的只能是 0-255 的数字,类似于 exit。
[root@localhost ~]# vim test1.sh
#!/bin/bash
fun () {
echo ""
exit
}
fun
:wq
[root@localhost ~]# bash test1.sh [root@localhost ~]# echo $?
#函数传参
[root@localhost ~]# vim test1.sh
#!/bin/bash
fun () {
echo "Hello $1"
}
fun world
:wq
[root@localhost ~]# bash test1.sh
Hello world
2. shell正则表达式
正则表达式在每种语言中都会有,功能就是匹配符合你预期要求的字符串。
Shell 正则表达式分为两种:
基础正则表达式
扩展正则表达式:扩展的表达式有+、?、| 和()
正则表达式就是为了处理大量的文本、字符串而定义的一套规则和方法
通过定义的这些特殊符号的辅助,系统管理员就可以快速过滤,替换或输出需要的字符串。Linux正则表达式一般以行为单位处理。
1> 正则表达式和通配符的本质区别
1)不需要思考的判断方法:在三剑客awk,sed,grep,egrep都是正则,其他都是通配符
2)区别通配符和正则表达式最简单的方法:
(1)文件目录名===>通配符
(2)文件内容(字符串,文本【文件】内容)===>正则表达式
以grep工具说明常用正则表达式:
|
符号 |
描述 |
实例 |
|
. |
一个点.匹配任意单个字符(必须存在) |
例子:l..e 可以表示 love like leee 不可以表示的 labcde le lee [root@localhost like love lect [root@localhost like love |
|
^ |
匹配前面字符串开头 |
匹配abc开头的行 [root@localhost abc you love me i love you abc [root@localhost abc you love me |
|
$ |
匹配前面字符串结尾 |
匹配abc结尾的行 [root@localhost abc you love me i love you abc [root@localhost i love you abc |
|
|
过滤掉空行 [root@localhost 123fsasf12 #空行 fasfdsadfsa adasfa12 123ddfs 167dsaf daf [root@localhost 123fsasf12 fasfdsadfsa adasfa12 123ddfs 167dsaf daf |
|
|
* |
匹配前一个字符的零个或多个 |
a* 表示出现任意个a的情况 [root@localhost abcaa bcacd aaabc cbda zxcv [root@localhost a aa a aaa a a*b 表示b前面有任意个a的情况(可以是0个) [root@localhost abcaa bcacd aaabc cbda [root@localhost ab b aaab b |
|
.* |
表示任意长度的任意字符 |
例子:过滤出一行中a在前,b在后的行 条件: 包含 a 和 b 字母 a 必须在 b前面 [root@localhost abcaa bcacd aaabc cbda zxcv [root@localhost abcaa aaabc |
|
+(扩展正则) |
表示其前面的字符出现最少一次的情况 |
[root@localhost abcaacdfabvfab bcacd aaabc cbda zxcv [root@localhost abcaacdfabvfab aaabc [root@localhost abcaacdfabvfab aaabc [root@localhost [root@localhost |
|
? (扩展正则) |
表示其前面的字符出现最多一次的情况(可以0个 |
匹配ac或c(c前面出现的a为0或多个,ac相连) [root@localhost abcaacdfabvfab bcacd aaabc cbda zxcv [root@localhost [root@localhost abcaacdfabvfab bcacd aaabc cbda zxcv |
|
[ ] |
表示范围内的一个字符 |
[root@localhost 123fsasf12 fasfdsadfsa adasfa12 123ddfs 167dsaf daf 以a-z开头(字母开头) [root@localhost fasfdsadfsa adasfa12 daf |
|
[ .-.] |
匹配中括号中范围内的任意一个字符 |
匹配所有字母 echo -e |
|
[^] |
匹配[^字符]之外的任意一个字符 |
[root@localhost 123fsasf12 fasfdsadfsa adasfa12 123ddfs 167dsaf daf [root@localhost #不以字母开头的文件 123fsasf12 123ddfs 167dsaf |
|
{n}或者{n,} |
{n}表示严格匹配n个字符 {n,}匹配花括号前面字符至少 n个字符 |
[root@localhost bbbasdfhhf bb1235sdf babababba agdsaf asdf [root@localhost bbbasdfhhf bb1235sdf babababba [root@localhost #至少3个 bbbasdfhhf [root@localhost bbbasdfhhf |
|
|
规则一:花括号和分组在基础正则中需要加上斜线进行转义,但是在扩展正则中不要加斜线 |
|
|
{n,m} |
匹配花括号前面字符至少 n个字符,最多 m 个字符 |
[root@localhost #a前面至少2个b最多3个b bbbasdfhhf babababba [root@localhost #f和f之间最少2个h bbbasdfhhf [root@localhost #a到f之间最多1个s agdsaf |
|
\< |
锚定单词首部(单词一般以空格或特殊字符做分隔) |
[root@localhost df:ceroot:fasdf:rootvdga agd dsaf rootadg sfafa [root@localhost #以特殊字符分割,首部为root df:ceroot:fasdf:rootvdga agd dsaf rootadg dagaggd |
|
\> |
锚定单词尾部(单词一般以空格或特殊字符做分隔) |
[root@localhost #以特殊字符分割,尾部为root df:ceroot:fasdf:rootvdga |
|
( ) |
\1 调用前面的第一个分组 |
[root@localhost efdgfd1fasdf1 1aefeeea2dfg 3fdavfdva3fggfdf 33dfagqr23zdfbd abffsh23sfg [root@localhost #调用前面的第一个数字分组,过滤出一行中有两个相同数字的行 efdgfd1fasdf1 3fdavfdva3fggfdf 33dfagqr23zdfbd [root@localhost #调用前面的第一个数字分组,找出行首和行位相同数字的行 1aefeeea2dfg1 |
|
|
第二个规则:在单词锚定中和分组调用中,基础正则和扩展正则都必须加斜线 |
|
|
|(扩展正则) |
匹配竖杠两边的任意一个 |
过滤出cat 或者Cat # grep # grep |
3. 总结
1> 正则表达式
一、字符匹配
.
[]
[^]
二、次数匹配
*
\{m,n\}
三、锚定
^
$
\<
\>
四、分组
\(\)
\1
2> 扩展正则表达式
grep -E
egrep
一、字符匹配
.
[]
[^]
二、次数匹配
*
{m,n}
+ 表示其前面的字符出现最少一次的情况
?表示其前面的字符出现最多一次的情况
三、锚定
^
$
\<
\>
四、分组
()
\1
\2
五、或
|
正则表达式中的{}以及()都需要加上\进行转义,而扩展正则表达式不需要
|, ?,+是扩展正则独有的
锚定单词首部和尾部在扩展正则以及正则中都需要加上\
Shell函数和正则表达式的更多相关文章
- shell(shell函数、shell正则表达式)
本章内容 shell函数 shell正则表达式 1.shell函数 linux shell 可以用户定义函数,然后在shell脚本中可以随便调用. 格式: funname () { CMD #函数体 ...
- shell脚本三——正则表达式
shell函数:shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数.给这段代码起个名字称为函数名,后续可以直接调用该段代码. 格式:fun() { 命令 } Shell ...
- Shell入门教程:Shell函数详解
Shell函数类似于Shell脚本,里面存放了一系列的指令,不过Shell的函数存在于内存,而不是硬盘文件,所以速度很快,另外,Shell还能对函数进行预处理,所以函数的启动比脚本更快. 1.函数定义 ...
- Shell入门教程:Shell函数的返回值
shell函数返回值一般有3种方式: 1.return语句(默认的返回值) shell函数的返回值可以和其他语言的返回值一样,通过return语句返回. 比如: #!/bin/bash functio ...
- (转)Shell函数
Shell函数类似于Shell脚本,里面存放了一系列的指令,不过Shell的函数存在于内存,而不是硬盘文件,所以速度很快,另外,Shell还能对函数进行预处理,所以函数的启动比脚本更快. 1. 函数 ...
- 任督二脉之Shell中的正则表达式
VBird说学习Linux,掌握了Shell和正则就相当于打通了任督二脉,此后能力的成长才会突飞猛进. Shell的基础学习之前已经总结了一篇博客:http://www.cnblogs.com/jyz ...
- Linux Shell系列教程之(十五) Shell函数简介
本文是Linux Shell系列教程的第(十五)篇,更多Linux Shell教程请看:Linux Shell系列教程 函数可以将一个复杂功能划分成若干模块,从而使程序结构更加清晰,代码重复利用率更高 ...
- Shell函数的简单应用
Shell函数的简单应用 在脚本内给函数传参: #!/bin/bash . /etc/init.d/functions CheckUrl (){ curl -I -s $ | head - } Che ...
- Shell函数语法
Shell函数语法 定义函数: function 函数名(){ 指令... } 调用函数,方法1: 函数名 调用函数,方法2: 函数名 参数一 参数二 return在函数里面使用会跳出函数并 ...
随机推荐
- H5+JS实现手机摇一摇功能
在做微信活动页面的时候,经常会需要实现手机摇一摇功能,比如“摇一摇,拿好礼”. 为了实现它,就需要用到HTML5的DeviceOrientation特性.它提供的DeviceMotion事件封装了设备 ...
- bzoj4145 [AMPPZ2014]The Prices(状压dp)
Description 你要购买m种物品各一件,一共有n家商店,你到第i家商店的路费为d[i],在第i家商店购买第j种物品的费用为c[i][j], 求最小总费用. Input 第一行包含两个正整数n, ...
- Luogu P1417烹调方案【dp/背包】By cellur925
题目传送门 我们看到这道题,就会想起背包.于是我就一顿01背包敲,结果发现只有30分.后来看题解发现需要对输入的食材进行排序. 我们回想国王游戏一题,各位大臣的排列顺序会对权值造成影响,所以我们就预先 ...
- Apache Zeppelin是什么?
Apache Zeppelin提供了web版的类似ipython的notebook,用于做数据分析和可视化.背后可以接入不同的数据处理引擎,包括spark, hive, tajo等,原生支持scala ...
- Jquery | 基础 | 慕课网 | 层级选择器
选择器中的层级选择器处理关系类型: 子元素 后代元素 兄弟元素 相邻元素 <!DOCTYPE html> <html> <head> <meta http-e ...
- Jmeter安装说明
本文主要介绍Jmeter工具的安装 一.安装JDK 1.下载jdk,到官网下载jdk,下载jkd1.8即可,地址:http://www.oracle.com/technetwork/java/java ...
- Poj 3666 Making the Grade (排序+dp)
题目链接: Poj 3666 Making the Grade 题目描述: 给出一组数,每个数代表当前位置的地面高度,问把路径修成非递增或者非递减,需要花费的最小代价? 解题思路: 对于修好的路径的每 ...
- Educational Codeforces Round 24 B
n children are standing in a circle and playing a game. Children's numbers in clockwise order form a ...
- 474 Ones and Zeroes 一和零
在计算机界中,我们总是追求用有限的资源获取最大的收益.现在,假设你分别支配着 m 个 0 和 n 个 1.另外,还有一个仅包含 0 和 1 字符串的数组.你的任务是使用给定的 m 个 0 和 n 个 ...
- scau 17967 大师姐唱K的固有结界 分类暴力 + RMQ
由于能放两次,那么分类, 1.连续使用,(这个直接O(n^2)暴力) 2.分开使用. 分开使用的话,首先暴力枚举,用T时间,能从第1个位置,唱到第几首歌,然后剩下的就是从pos + 1, n这个位置, ...