10.3函数及脚本的综合应用

前端之家收集整理的这篇文章主要介绍了10.3函数及脚本的综合应用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

函数及脚本的综合应用

一 shell函数

shell函数shell允许将一组命令集或语句形成一个可用块,这些块称为shell函数

函数由两部分组成:函数标题函数体;标题函数名;函数函数内的命令集合;标题名应该唯一;如果不是,将会混淆结果,因为脚本在查看调用脚本前将首先搜索函数调用相应的shell

定义函数的格式为:

函数名(){

命令1

...

}

如果愿意,可在函数名前加上关键字function,这取决于使用者。

function函数名()

{

命令1

...

}

应用

例1:删除文件中的空行

这个脚本(脚本名为del.lines)可以处理一个或多个文件。每个文件在用sed删除空行之前要先核实是否存在。

sed的输出被导入一个文件名中含有$ $的临时文件,最后这个临时文件又被移回到原来的文件中。

该脚本使用shift命令取得所有的文件名,用while循环逐个处理所有的文件,直至处理完为止。可以使用del.lines --help获得一个简短的帮助

@H_404_147@#!/bin/bash

@H_404_147@TEMP_F="/tmp/del.lines.$$"

@H_404_147@#定义函数

@H_404_147@usage()

@H_404_147@{

@H_404_147@#提示脚本运行格式并查看帮助信息

@H_404_147@echo "Usage:`basename $0` file [file...]"

@H_404_147@echo "try `basename $0` -help for more info"

@H_404_147@exit 1

@H_404_147@}

@H_404_147@#如果脚本后面的参数个数为0,即没有参数

@H_404_147@if [ $# -eq 0 ]

@H_404_147@then

@H_404_147@#则提示函数里的内容

@H_404_147@usage

@H_404_147@fi

@H_404_147@while [ $# -gt 0 ]

@H_404_147@do

@H_404_147@#提示正在执行的是位置1的参数

@H_404_147@echo "...$1"

@H_404_147@#如果位置1的参数时--help,则显示帮助信息

@H_404_147@case $1 in

@H_404_147@--help)

@H_404_147@echo "Use this script to delete all blank lines from a text file(s)"

@H_404_147@exit 0

@H_404_147@;;

@H_404_147@*)

@H_404_147@FILE_NAME=$1

@H_404_147@#判断位置1的文件是否存在

@H_404_147@if [ -f $1 ]

@H_404_147@then

@H_404_147@#删除文件内的空行(不是空格键的空行),并生成新的文件

@H_404_147@sed '/^$/d' $FILE_NAME > $TEMP_F

@H_404_147@mv $TEMP_F $FILE_NAME

@H_404_147@else

@H_404_147@echo "$0 cannot find this file: $1"

@H_404_147@fi

@H_404_147@#将 $1~$9 依次向左传递

@H_404_147@shift

@H_404_147@;;

@H_404_147@esac

@H_404_147@done

保存后给脚本文件增加执行权限:chmod +x del.lines

执行脚本进行测试:

函数及脚本的综合应用" src="http://s15.sinaimg.cn/middle/c1444d1dzx6D3W6u9dkce&690">

注:

1、basename命令能够从路径中分离出文件名。通常用于shell脚本中

2、shift语句用于迁移位置变量,将 $1~$9 依次向左传递

例如,若当前脚本程序获得的位置变量如下:

$1=file1、$2=file2、$3=file3、$4=file4

则执行一次shift命令后,各位置变量为:

$1=file2、$2=file3、$3=file4

再次执行shift命令后,各位置变量为:

$1=file3、$2=file4

例2:如果某些日志文件超过了特定的长度(如8K),那么它的内容将被倒换到另一个文件中,并清除原有文件中的内容.

系统中的有些日志文件增长十分迅速,每天手工检查这些日志文件的长度并倒换这些日志文件(通常是给文件名加个时间戳)是非常乏味的。可以编写一个脚本来自动完成这项工作。该脚本将提交给cron进程来运行,如果某个日志文件超过了特定的长度,那么它的内容将被倒换到另一个文件中,并清除原有文件中的内容

该脚本中日志文件的长度限制是由变量BLOCK_LIMIT设定的。这一数字代表了块数目,在本例中是8(块大小默认为4K)。可以按照自己的需求把这一数字设得更高。所有要检查的日志文件名都保存在变量LOGS中。

这里使用了一个for循环来依次检查每一个日志文件,使用du命令来获取日志文件长度。

如果相应的文件长度大于BLOCK_LIMIT变量所规定的值,那么该文件将被拷贝到一个文件

名含有时间戳的文件中,原先的文件长度将被截断为0。

@H_404_147@#!/bin/bash

@H_404_147@BLOCK_LIMIT=8

@H_404_147@MYDATE=$(date +%d%m)

@H_404_147@#定义文件列表集合

@H_404_147@LOGS="/var/log/maillog /var/log/messages"

@H_404_147@for LOG_FILE in $LOGS

@H_404_147@do

@H_404_147@if [ -f $LOG_FILE ]

@H_404_147@then

@H_404_147@F_SIZE=$(du -a $LOG_FILE | awk '{print $1}')

@H_404_147@else

@H_404_147@echo "$0 connot find $LOG_FILE"

@H_404_147@#文件不存在,直接不用执行下面的语句重新开始循环

@H_404_147@continue

@H_404_147@fi

@H_404_147@if [ "$F_SIZE" -gt "$BLOCK_LIMIT" ]

@H_404_147@then

@H_404_147@cp $LOG_FILE $LOG_FILE$MYDATE

@H_404_147@#清空原来的文件内容

@H_404_147@>$LOG_FILE

@H_404_147@fi

@H_404_147@done

注:du 并不是显示文件的实际大小,而是显示文件所占用的 block 大小,默认linux系统分区的 block size 是4k,也就是说即使文件只有1个字节,也会占用4k. ls -l则是文件的实际大小

猜你在找的正则表达式相关文章