您的位置:首页 > 运维架构 > Shell

Shell 函数、数组与正则表达式

2017-02-14 20:37 225 查看
防伪码:白日依山尽,黄河入海流。5.1 函数
格式:func() {command}示例 1:#!/bin/bashfunc() {echo "This is a function."}func# bash test.shThis is a function.


Shell 函数很简单,函数名后跟双括号,再跟双大括号。通过函数名直接调用,不加小括号。示例 2:函数返回值#!/bin/bashfunc() {VAR=$((1+1))return $VARecho "This is a function."}funcecho $?# bash test.sh2

return 在函数中是定义状态返回值,返回并终止函数,但返回的只能是数字,类似于 exit 0。示例 3:函数传参#!/bin/bashfunc() {echo "Hello $1"}func world# bash test.shHello world

通过 Shell 位置参数给函数传参。5.2 数组数组是相同类型的元素按一定顺序排列的集合。格式:array=(元素 1 元素 2 元素 3 ...)用小括号初始化数组,元素之间用空格分隔。定义方法 1:初始化数组array=(a b c)定义方法 2:新建数组并添加元素array[下标]=元素定义方法 3:将命令输出作为数组元素array=($(command))数组操作:获取所有元素# echo ${array[*]} # *和@ 都是代表所有元素a b c获取元素下标# echo ${!a[@]}0 1 2获取数组长度# echo ${#array[*]}3获取第一个元素# echo ${array[0]}a获取第二个元素# echo ${array[1]}b获取第三个元素# echo ${array[2]}c添加元素# array[3]=d# echo ${array[*]}a b c d添加多个元素# array+=(e f g)# echo ${array[*]}a b c d e f g删除第一个元素# unset array[0] # 删除会保留元素下标# echo ${array[*]}b c d e f g删除数组# unset array数组下标从 0 开始。示例 1:讲 seq 生成的数字序列循环放到数组里面#!/bin/bashfor i in $(seq 1 10); doarray[a]=$ilet a++doneecho ${array[*]}# bash test.sh1 2 3 4 5 6 7 8 9 10

示例 2:遍历数组元素方法 1:#!/bin/bashIP=(192.168.1.1 192.168.1.2 192.168.1.3)for ((i=0;i<${#IP[*]};i++)); doecho ${IP[$i]}done# bash test.sh192.168.1.1192.168.1.2192.168.1.3

方法 2:#!/bin/bashIP=(192.168.1.1 192.168.1.2 192.168.1.3)for IP in ${IP[*]}; doecho $IPdone

正则表达式在每种语言中都会有,功能就是匹配符合你预期要求的字符串。Shell 正则表达式分为两种:基础正则表达式:BRE(basic regular express)扩展正则表达式:ERE(extend regular express),扩展的表达式有+、?、|和()下面是一些常用的正则表达式符号,我们先拿 grep 工具举例说明。
符号描述示例
.匹配除换行符(\n)之外的任意单个字符匹配 123:echo -e "123\n456" |grep '1.3'
^ 匹配前面字符串开头匹配以 abc 开头的行:echo -e "abc\nxyz" |grep ^abc
$匹配前面字符串结尾匹配以 xyz 结尾的行:echo -e "abc\nxyz" |grep xyz$
*匹配前一个字符零个或多个匹配 x、xo 和 xoo:echo -e "x\nxo\nxoo\no\noo" |grep "xo*"x 是必须的,批量了 0 零个或多个
+ 匹配前面字符 1 个或多个匹配 abc 和 abcc:echo -e "abc\nabcc\nadd" |grep -E 'ab+'匹配单个数字:echo "113" |grep -o '[0-9]'连续匹配多个数字:echo "113" |grep -E -o '[0-9]+'
匹配前面字符 0 个或 1 个匹配 ac 或 abc:echo -e "ac\nabc\nadd" |grep -E 'a?c'
[ ]匹配中括号之中的任意一个字符匹配 a 或 c:echo -e "a\nb\nc" |grep '[ac]'
[ .-.]匹配中括号中范围内的任意一个字符匹配所有字母:echo -e "a\nb\nc" |grep '[a-z]'
[^]匹配[^字符]之外的任意一个字符匹配 a 或 b:echo -e "a\nb\nc" |grep '[^c-z]'匹配末尾数字:echo "abc:cde;123" |grep -E'[^;]+$'
^[^]匹配不是中括号内任意一个字符开头的行匹配不是#开头的行:grep '^[^#]' /etc/httpd/conf/httpd.conf
{n}或{n,}匹配花括号前面字符至少 n个字符匹配 abc 字符串(至少三个字符以上字符串):echo -e "a\nabc\nc" |grep -E '[a-z]{3}'
{n,m}匹配花括号前面字符至少 n个字符,最多 m 个字符匹配 12 和 123(不加边界符会匹配单个字符):echo -e "1\n12\n123\n1234" |grep -E -w -o '[0-9]{2,3}'
\< 边界符,匹配字符串开始匹配开始是 123 和 1234:echo -e "1\n12\n123\n1234" |grep -w '\<123'
\>边界符,匹配字符串结束匹配结束是 1234:echo -e "1\n12\n123\n1234" |grep '4\>'
( )单元或组合:将小括号里面作为一个组合分组:匹配小括号中正则表达式或字符。\n 反向引用,n 是数字,从 1 开始编号,表示引用第 n 个分组匹配的内容

单元:匹配 123a 字符串echo "123abc" |grep -E -o '([0-9a-z]){4}'分组:匹配 11echo "113abc" |grep -E -o '(1)\1'匹配出现 xo 出现零次或多次:echo -e "x\nxo\nxoo\no\noo" |egrep "(xo)*"

|匹配竖杠两边的任意一个匹配 12 和 123:echo -e "1\n12\n123\n1234" |grep -E '12\>|123\>'
\转义符,将特殊符号转成原有意义1.2,匹配 1.2:1\.2,否则 112 也会匹配到
Posix字符描述
[:alnum:] 等效[a-zA-Z0-9]
[:alpha:] 等效[a-zA-Z]
[:lower:] 等效[a-z]
[:upper:]等效[A-Z]
[:digit:]等效[0-9]
[:space:] 匹配任意空白字符,等效[\t\n\r\f\v]
[:graph:]非空白字符
[:blank:] 空格与定位字符
[:cntrl:] 控制字符
[:print:]可显示的字符
[:punct:] 标点符号字符
[:xdigit:]十六进制
示例:echo -e "1\n12\n123\n1234a" |grep '[[:digit:]]'在 Shell 下使用这些正则表达式处理文本最多的命令有下面几个工具:
命令描述
grep默认不支持扩展表达式,加-E 选项开启 ERE。如果不加-E 使用花括号要加转义符\{\}
egrep 支持基础和扩展表达式
awk支持 egrep 所有的正则表达式
sed默认不支持扩展表达式,加-r 选项开启 ERE。如果不加-r 使用花括号要加转义符\{\}
支持的特殊字符描述
\w匹配任意数字和字母,等效[a-zA-Z0-9_]
\W与\w 相反,等效[^a-zA-Z0-9_]
\b 匹配字符串开始或结束,等效\<和\>
\s 匹配任意的空白字符
\S 匹配非空白字符
空白符描述
\n 换行符
\r回车符
\t 水平制表符
\v垂直制表符
\0 空值符
\b 退后一格
谢谢观看,真心的希望能帮到您!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  正则 表达式 杨文