#!/bin/sh################################ 名称: MvOtherCdrTo251.sh## 描述: /ocs/data/output目录下的25开头(251,257,258除外)对应目录下的/normal/bak下的文件 全部转移到/ocs/data/output/251/normal/bak## 参数: 暂无## 作者: 小工匠## 日期: 2017-06-17## 版本:V1.0## 备注:使用时注意修改TARGET_MENU的值,测试用,取的是bak目录###############################定义退出标识符, 脚本执行后,通过echo $? 查看退出标识符,即上个命令或者脚本的返回结果EXIT_FAILURE=1 #Failing exit status EXIT_SUCCESS=0 #Successful exit status #开始时间BEGIN_TIME=`date +%s`#当前执行脚本的全路径SCRIPT_PATH=$(cd `dirname $0`; pwd)SCRIPT_NAME=`basename $0` #日志路径LOG_LOCATION=/ocs/tools/OperCDR/logs#判断目录是否存在,存在则进入$1所在的目录,不存在不创建目录,直接退出Check_TargetMenu(){ if [ ! -d $1 ];then echo -e "Target Menu \033[31m$1 does not exist \033[0m,existing the script \033[31m$SCRIPT_PATH/$SCRIPT_NAME\033[0m ,check fisrt please" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1 exit $EXIT_FAILURE else cd $1 echo Current Directory $1 fi}#定义脚本执行取话单的目录 暂不考虑外部传参TARGET_MENU='/ocs/data/output_bak0617'#检查目录是否存在,不存在暂不创建目录,直接退出当前执行的脚本,存在进入对应的目录Check_TargetMenu $TARGET_MENUecho "==========================begin `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#循环遍历目录,业务操作#注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况 .#可以改用 find . -name "in*.s" | xargs ls 'in*.s' for operatingDir in `ls -d 25*` do #如果不是251、257、258目录,则进行mv操作 if [ $operatingDir != '251' ]&&[ $operatingDir != '257' ]&&[ $operatingDir != '258' ]; then echo $operatingDir #获取该目录绝对路径 Current_oper_dir=$(cd $TARGET_MENU/$operatingDir && pwd) echo Current_oper_dir $Current_oper_dir #检验目录是否存在,不存在,不创建,直接退出 Dir_Normal_bak=$Current_oper_dir/normal/bak Check_TargetMenu $Dir_Normal_bak #转移文件的目标目录 Final_Menu=$TARGET_MENU/251/normal/bak #循环遍历文件,注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况 for file in `ls in*.s` do mv $file $Final_Menu echo "$file moved to $Final_Menu successfully " >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1 done fi done #结束时间END_TIME=$(date +%s)echo "==========================end `date "+%Y-%m-%d %H:%M:%S"`=================================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#计算脚本执行时间#也可以 通过下面的方式统计 time 脚本名称#....省略执行过程#real 0m2.024s#user 0m0.007s#sys 0m0.008secho "==========================time consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1#输出一行空行到日志中,方便区分每次执行的日志echo "" >>$LOG_LOCATION/MvOtherCdrTo251.log 2>&1exit $EXIT_SUCCESS