#前言:今天我们来聊聊shell脚本中的函数知识,看一下函数的优势,执行过程和相关的使用案例,我们也来看一下shell和python的函数书写方式有什么不同

#简介

、函数也具有别名类似的功能
、函数是把程序里多次调用相同的代码部分定义成一份,然后给这份代码定义个名字,如果出现重复的就调用就行了

#函数的优势

、把相同的程序段定义成函数,可以减少整个程序的代码量
、可以让程序代码结构更清晰
、增加程序的可读、易读性、以及管理性
、可以实现程序功能模块化,不同的程序使用函数模块化

#语法格式

函数名(){
指令
return n
} 规范写法
function 函数名(){
指令
return n
}
#提示:shell的返回值是exit输出返回值,函数里用return输出返回值

#函数的执行

调用函数
#1、直接执行函数名即可(不带括号)
#注意
执行函数时,函数后的小括号不要带了
函数定义及函数整体必须在要执行的函数名的前面定义 #2、带参数的函数执行方法
函数名 参数1 参数2 #提示:函数的传参和脚本的传参类似
#shell的位置参数($1 $2 $3 $4 $5 $# $* $? $@)都可以时函数的参数
#$0比较特殊,仍然是父脚本的名称
#在shell函数里面,return命令功能与shell里的exit类似,作用时跳出函数
#在shell函数里面使用exit会退出整个shell脚本,而不是退出shell函数
#return语句会返回一个退出值(返回值)给调用函数的程序

#我们来看一下python的函数书写方式

#提示:def是define的意思,定义

最基本的语法:
def 函数名():
函数体
   函数名() #调用函数 带有参数的语法
def 函数名(形参列表):
函数体(代码块,return) 函数名(实参列表) :调用

#看一下执行过程

# def wan():  #定义函数
# print("今天一起去玩")
# print("去哪里玩呢")
# print("我不知道")
# wan() #调用函数
'''讲解执行的过程
.定义函数wan()
.调用函数wan()
.准备开始执行函数
.打印,今天一起去玩
.打印,去哪里完
.打印,我不知道
.函数执行完毕,本次调用完毕,wan()函数调用完毕
'''

#使用

#例1:没有去调用函数

[root@shell scripts]# pwd
/scripts
[root@shell scripts]# cat hs01.sh
#!/bin/bash guoke(){
echo "I am guoke"
}
[root@shell scripts]# sh hs01.sh
[root@shell scripts]# #如果没有去调用函数的话,那么就没有输出

#例2:调用函数

[root@shell scripts]# cat hs01.sh
#!/bin/bash guoke(){
echo "I am guoke"
}
guoke #调用函数
[root@shell scripts]# sh hs01.sh
I am guoke

#例3:多次调用

[root@shell scripts]# cat hs01.sh
#!/bin/bash guoke(){
echo "I am guoke"
}
guoke
guoke
guoke [root@shell scripts]# sh hs01.sh
I am guoke
I am guoke
I am guoke

#例4:将函数写到/etc/init.d/functions里面,然后通过其他脚本进行调用

#/etc/init.d/functions
boy(){
echo "I am guoke-boy"
} return
#提示:不要放在return 0后面,要不然就是退出了,没有调用 [root@shell scripts]# cat hs01.sh #通过脚本去调用boy函数
#!/bin/bash . /etc/init.d/functions #引入系统函数库
guoke(){
echo "I am guoke"
}
guoke
boy #调用/etc/init.d/functions中的函数
[root@shell scripts]# sh hs01.sh #执行之后打印
I am guoke
I am guoke-boy

#例5:将函数写到/etc/init.d/functions里面,通过其他脚本进行调用然后传参

#/etc/init.d/functions
boy(){
echo "I am $1"
}
#提示:$1:脚本的传入的第一个参数
[root@shell scripts]# cat hs01.sh #通过脚本去调用boy函数
#!/bin/bash . /etc/init.d/functions #引入系统函数库
guoke(){
echo "I am guoke"
}
guoke
boy guoke-boy #调用/etc/init.d/functions中的函数,后面接着传参 [root@shell scripts]# sh hs01.sh #执行之后打印
I am guoke
I am guoke-boy

#例6:设置提示函数,如果传的参数的值不符合就打印帮助函数

[root@shell scripts]# cat hs02.sh
#!/bin/bash
usage(){
echo "Usage:
$ key beginservernum endservernum example:
$ ff "
} [[ $# != ]] && usage && exit 1 #如果传入的参数不等于3的话,就调用后面的函数,并退出脚本
[[ -z $ || -z $ || -z $ ]] && usage && exit 1 #如果传入的$1,$2,$3三个参数的值为空,那么就调用后面的函数,并退出脚本 [root@shell scripts]# sh hs02.sh 33 #当传入的参数不等于3个的时候就执行usage函数,并退出脚本
Usage:
hs02.sh key beginservernum endservernum example:
hs02.sh ff

#例7:将函数的传参转换成脚本文件命令行传参,判断任意指定的URL是否存在异常

[root@shell scripts]# cat hs03.sh
#!/bin/bash . /etc/init.d/functions function usage(){
echo $"usage:$0 url"
exit
} function check_url(){
wget --spider -q -o /dev/null --tries= -T $
if [ $? -eq ];then
action "$1 is success." /bin/true
else
action "$1 is failure." /bin/false
fi
} function main(){
if [ $# -ne ];then
usage
fi
check_url $
}
main $*

#参数解释

. /etc/init.d/functions  #引入系统函数库
function usage(){ #帮助函数 function check_url(){ #检测URL函数
wget --spider -q -o /dev/null --tries= -T $ #--spider:判断网址是否有效,-q:不显示执行过程,-o:将软件输出信息保存到软件,-T:指定超时时间
action "$1 is success." /bin/true #action:调用系统函数库的用法 function main(){ #主函数
if [ $# -ne ];then #判断:如果传参的参数不等1个,那么久打印帮助函数,提示用户
check_url $ #接收函数的传输
main $* #$*:把命令行接收的所有参数作为函数参数传给函数内部

#测试

[root@shell scripts]# sh hs03.sh   #如果没有加参数,就调用提示函数
usage:hs03.sh url
[root@shell scripts]# sh hs03.sh www.guokeboy.com #输入错误地址
www.guokeboy.com is failure. [FAILED](失败)
[root@shell scripts]# sh hs03.sh www.baidu.com #输入正确地址
www.baidu.com is success. [ OK ]

#例8:给任意字符串加指定颜色

[root@shell scripts]# cat hs04.sh
#!/bin/bash RED_COLOR='\E[1;31m'
GREEN_COLOR='\E[1;32m'
YELLOW_COLOR='\E[1;33m'
BLUE_COLOR='\E[1;34m'
PINK='\E[1;35m'
RES='\E[0m' usage(){
if [ $# -ne ];then
echo "USAGE:$0 {red|green|yellow|blue|pink}" contents
exit
fi
} color(){
case "$1" in
red)
echo -e "${RED_COLOR} $2 ${RES}"
;;
green)
echo -e "${GREEN_COLOR} $2 ${RES}"
;;
yellow)
echo -e "${YELLOW_COLOR} $2 ${RES}"
;;
blue)
echo -e "${BLUE_COLOR} $2 ${RES}"
;;
*)
usage
esac
} main(){
if [ $# -ne ];then
usage
fi
color $ $
}
main $*

#参数解释

#.定义颜色变量
数字对应的颜色:(黑色)、(红色)、(绿色)、(黄色)、(蓝色、(粉红)、(青色)、(白色)
#.定义帮助函数
#.定义颜色函数,使用case来获取输入的值
#.主函数,判断输入的参数是否为2个,如果不是就调用帮助函数

#测试

#如果执行脚本,不加参数的话就打印帮助函数

#例9:使用shell函数开发rsync服务启动脚本

#使用start、stop、restart函数将代码 模块化,使用系统函数action优化显示

[root@shell init.d]# cat rsyncd
#!/bin/bash
#chkconfig:
#description: Rsyncd start scripts by guoke. . /etc/init.d/functions function usage(){
echo $"usage:$0 {start|stop|restart}"
exit
} function start(){
rsync --daemon
sleep
if [ `netstat -unplt | grep rsync | wc -l` -ge ];then
   action "rsyncd is started." /bin/true
else
   action "rsyncd is started." /bin/false
fi
} function stop(){
killall rsync &>/dev/null
sleep
if [ `netstat -unptl | grep rsync |wc -l` -eq 0 ];then
   action "rsyncd is stopped." /bin/true
else
   action "rsyncd is stopped." /bin/false
fi
} function restart(){
stop
sleep 2
start
} function main(){
if [ $# -ne ];then
usage
fi
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
sleep
start
;;
*)
usage esac
}
main $*

#参数解释:引入系统函数库,定义帮助函数,然后定义start函数,stop函数,restart函数,定义主函数,主函数里面首先使用if判断传入的参数是不是为一个,如果不是就调用帮助函数,然后使用case语句获取传入的参数,再调用相关的函数,$*:把命令行接收的所有参数作为函数参数传给函数内部

#测试

[root@shell init.d]# sh rsyncd stop
rsyncd is stopped. [ OK ]
[root@shell init.d]# sh rsyncd start
rsyncd is started. [ OK ]
[root@shell init.d]# sh rsyncd restart
rsyncd is stopped. [ OK ]
rsyncd is started. [ OK ]

#总结:将脚本中功能进行模块化之后,就会使脚本比较易读和清晰,提升管理效率。好了,这次就分享到这了,写的不好地方还望指出,多多交流提高,下次再会。。。

												

shell脚本的函数介绍和使用案例的更多相关文章

  1. shell脚本编程基础介绍

    Linux系统——shell脚本编程基础介绍 1.什么是shell 它是一个命令解释器,在linux/unix操作系统的最外层,负责直接与用户对话,把用户的输入解释给操作系统,并处理各种操作输出的结果 ...

  2. Linux Shell脚本编程-函数

    函数介绍  定义:把一段独立功能的的代码当做一个整体,并为之一个名字,命名的代码段,此即为函数:  功能:函数function是由若干条shell命令组成的语句块,实现代码重用和模块化编程.  注意: ...

  3. Shell脚本之八 函数

    一.函数定义 Linux shell 可以用户定义函数,然后在shell脚本中可以随便调用. shell中函数的定义格式如下: [ function ] funname [()] { action; ...

  4. Shell脚本(五)函数

    总结下shell中的函数用法 #!/bin/bash function add_v1() { echo "call function add" } function add_v2( ...

  5. Shell脚本学习 - 函数,输入输出重定向,文件

    函数 函数定义 [ function ] funname [()] { action; [return int;] } 定义时可以是function fun(),也可以直接fun(),不带参数 返回值 ...

  6. shell脚本之函数的使用

    把代码封装成函数,相当于造了一个“轮子”,之后就直接重复使用即可. 函数的创建 shell中函数的创建有2种方式 1.使用function关键字 语法 function test { ... } 2. ...

  7. shell脚本 4 函数与正则

    shell函数 shell中允许将一组命令集合或语句形成一段可用代码,这些代码块称为shell函数.给这段代码起个名字称为函数名,后续可以直接调用该段代码. 格式 func() {   #指定函数名 ...

  8. shell脚本之xargs使用的一些案例

    首先看一下文本信息: # cat text1.txt 1 2 3 4 5 使用xargs格式化一下: # cat text1.txt  | xargs 1 2 3 4 5 使用xargs格式化,每两个 ...

  9. Shell 脚本进阶,经典用法及其案例

    一.条件选择.判断 1.条件选择if (1)用法格式 if 判断条件 1 ; then 条件为真的分支代码 elif 判断条件 2 ; then 条件为真的分支代码 elif 判断条件 3 ; the ...

随机推荐

  1. Promise 的含义

    Promise 的含义 Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大.它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Pro ...

  2. grpc调试工具

    grpcurl 和 grpcui 都是调试grpc的利器,前者用于命令行,类似curl工具:后者是以web的形式进行调试的,类似postman工具. 有了这两款工具,我们不用写任何客户端代码,也能方便 ...

  3. java基础进阶篇(二)_Arraylist ------【java源码栈】

    前言 ArrayList 在开发中用到的频率很高,其中原生态提供的方法有一些很好用的重载版本,其中有的坑该跳得跳啊. 一.ArrayList的6种初始化方法1.构造方法 参数为空2.构造方法 参数为L ...

  4. CMSampleBufferRef解析

    CMTime:64位的value,32位的scale, media的时间格式 CMVideoFormatDesc:video的格式,包括宽高.颜色空间.编码格式.SPS.PPS CVPixelBuff ...

  5. Java 8 Optional 良心指南,建议收藏

    想学习,永远都不晚,尤其是针对 Java 8 里面的好东西,Optional 就是其中之一,该类提供了一种用于表示可选值而非空引用的类级别解决方案.作为一名 Java 程序员,我真的是烦透了 Null ...

  6. 什么是YUM

    什么是Yum Yum(全称为 Yellow dog Updater, Modified)是一个在RedHat以及CentOS等Linux系统中的Shell前端软件包管理器.基于RPM包管理,能够从指定 ...

  7. optimizing Wi-Fi solution for International School

    https://aweisoft.azurewebsites.net/Knowledge/Cisco/OptimizeWiFi/OptimizeWiFi.aspx Connect me on Link ...

  8. node打开本地应用程序

    1.打开浏览器 最简单的方法: const cp = require('child_process') cp.exec('start http://127.0.0.1:8889/'); // 自动打开 ...

  9. EF6.0 下sql语句自动生成的参数类型decimal(18,2)修改

    很多时候我们需要对插入到数据库的数据的精度做一个控制,例如sql server下保留6位小数使用numeric(10,6) .而到c#里对应的数据类型就是decimal ,但是使用EF6.0的crea ...

  10. BFC块级格式上下文介绍

    块级格式上下文(Block formatting context) 什么是BFC? 块格式化上下文(block formatting context) 是页面 CSS视觉渲染的一部分.它是用于决定块盒 ...