Shell-实际业务操作02
        【摘要】 
                    
                        
                    
                    
 文章目录
  
 
 
#!/bin/sh
##############################
## 名称: MvCdr4Classify.sh
## 描述: 将/ocs/data/ou...
    
    
    
    #!/bin/sh
##############################
## 名称: MvCdr4Classify.sh
## 描述: 将/ocs/data/output/251/normal/bak目录下的全部话单按照类别存储到对应的目录下(VOICE\DATA\SMS)
##			 规则 001 Data  002 Voice  004 SMS
##			 每种话单的目录下,有normal和gz_file两个目录 ,normal目录存放处理之后的话单,gz目录存放处理之后压缩的话单
## 参数: 暂无
## 作者: 小工匠
## 日期: 2017-06-17
## 版本:V1.0
## 备注:使用时注意修改SOURCE_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
#存放话单目标目录   
#mkdir -p new_folder/{folder_1,folder_2..} 将目录作为参数传入对应的函数 这种快捷的方式,不能有效的判断目录是否存在,暂时采用逐条创建的方式
VOICE_NORMAL=/bakcdr/cdrbak/VOICE/normal
VOICE_GZ_FILE=/bakcdr/cdrbak/VOICE/gz_file
DATA_NORMAL=/bakcdr/cdrbak/DATA/normal
DATA_GZ_FILE=/bakcdr/cdrbak/DATA/gz_file
SMS_NORMAL=/bakcdr/cdrbak/SMS/normal
SMS_GZ_FILE=/bakcdr/cdrbak/SMS/gz_file
#目标话单路径
TargetVoicePath=/bakcdr/cdrbak/VOICE
TargetDataPath=/bakcdr/cdrbak/DATA
TargetSmsPath=/bakcdr/cdrbak/SMS
#判断话单存放目录是否存在,存在则进入$1所在的目录,不存在不创建目录,直接退出
Check_SourceMenu(){
	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/MvCdr4Classify.log 2>&1
		exit $EXIT_FAILURE
	else
		cd $1
		echo Current Directory $1 
	fi
}
#判断存放话单的目标目录是否存,不存在则创建目录
Check_TargetMenu(){
	if [ ! -d $1 ] ; then 
		mkdir -p $1
		echo $1 does not exists , create successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
	fi
}
#处理话单文件
DealCDRFile(){
	#转移到Target对应目录下
	#mv $1 $2
  #echo "$1  moved to $2 successfully " >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
	
	#提取$1的日期,创建目录
	CDR_DATE=`echo $1 | awk 'BEGIN{FS="_"}{print substr($5,1,8)}'`
	echo $CDR_DATE
	
	FinalPath=$2/normal/$CDR_DATE
	if [ ! -d $FinalPath ] ; then 
		mkdir -p $FinalPath
	else
		#将话单转移到改目录下
		mv $1  $FinalPath
		echo "$1  moved to $FinalPath  successfully " >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
	fi
}
#检查话单存放目录是否存在 不存在则创建
Check_TargetMenu $VOICE_NORMAL
Check_TargetMenu $VOICE_GZ_FILE
Check_TargetMenu $DATA_NORMAL
Check_TargetMenu $DATA_GZ_FILE
Check_TargetMenu $SMS_NORMAL
Check_TargetMenu $SMS_GZ_FILE
#取话单的原始目录  暂不考虑通过外部参数传入
SOURCE_MENU='/ocs/data/output_bak0617/251/normal/bak'
#检查话单来源目录是否存在,不存在不创建目录,直接退出当前执行的脚本,存在则进入对应的目录
Check_SourceMenu $SOURCE_MENU
echo "==========================begin  `date "+%Y-%m-%d %H:%M:%S"`===============================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
#在原始话单路径下 提取话单    Check_SourceMenu已经校验并且进入了话单目录,无需重复进入 . 注意:如果ls获取的文件长度超过系统默认的命令缓冲区最大长度会导致错误。不适合目录下文件特别多的情况
for file in `ls in*.s`
do
	#从话单文件名称获取话单标识  001 Data  002 Voice  004 SMS
	CDR_FLAG=`echo $file | awk 'BEGIN{FS="_"}{print $3}'`
	#分支判断
	case $CDR_FLAG in 
		001) 
			DealCDRFile $file $TargetDataPath
			echo Deal Data CDR $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
			;;
		002)
			DealCDRFile $file $TargetVoicePath
			echo Deal Voice CDR  $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
			;;
		004)
			DealCDRFile $file $TargetSmsPath
			echo Deal SMS  CDR $CDR_FLAG  Successfully >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
			;;
		*)
			##匹配不到的文件,红色输出到日志, ERROR关键字
			echo -e "\033[31m ERROR  $file CDR_FLAG not in 001 002 004 \033[0m"  >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
			;;
	esac
	
done
#结束时间
END_TIME=$(date +%s)
echo "==========================end    `date "+%Y-%m-%d %H:%M:%S"`=================================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
#计算脚本执行时间
#也可以 通过下面的方式统计  time  脚本名称
#....省略执行过程
#real	0m2.024s
#user	0m0.007s
#sys	0m0.008s
echo "==========================time   consuming $(($END_TIME - $BEGIN_TIME)) seconds=================================================" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
#输出一行空行到日志中,方便区分每次执行的日志
echo "" >>$LOG_LOCATION/MvCdr4Classify.log 2>&1
exit $EXIT_SUCCESS
  
 - 1
 - 2
 - 3
 - 4
 - 5
 - 6
 - 7
 - 8
 - 9
 - 10
 - 11
 - 12
 - 13
 - 14
 - 15
 - 16
 - 17
 - 18
 - 19
 - 20
 - 21
 - 22
 - 23
 - 24
 - 25
 - 26
 - 27
 - 28
 - 29
 - 30
 - 31
 - 32
 - 33
 - 34
 - 35
 - 36
 - 37
 - 38
 - 39
 - 40
 - 41
 - 42
 - 43
 - 44
 - 45
 - 46
 - 47
 - 48
 - 49
 - 50
 - 51
 - 52
 - 53
 - 54
 - 55
 - 56
 - 57
 - 58
 - 59
 - 60
 - 61
 - 62
 - 63
 - 64
 - 65
 - 66
 - 67
 - 68
 - 69
 - 70
 - 71
 - 72
 - 73
 - 74
 - 75
 - 76
 - 77
 - 78
 - 79
 - 80
 - 81
 - 82
 - 83
 - 84
 - 85
 - 86
 - 87
 - 88
 - 89
 - 90
 - 91
 - 92
 - 93
 - 94
 - 95
 - 96
 - 97
 - 98
 - 99
 - 100
 - 101
 - 102
 - 103
 - 104
 - 105
 - 106
 - 107
 - 108
 - 109
 - 110
 - 111
 - 112
 - 113
 - 114
 - 115
 - 116
 - 117
 - 118
 - 119
 - 120
 - 121
 - 122
 - 123
 - 124
 - 125
 - 126
 - 127
 - 128
 - 129
 - 130
 - 131
 - 132
 - 133
 - 134
 - 135
 - 136
 - 137
 - 138
 - 139
 - 140
 - 141
 - 142
 - 143
 - 144
 - 145
 - 146
 - 147
 
文章来源: artisan.blog.csdn.net,作者:小小工匠,版权归原作者所有,如需转载,请联系作者。
原文链接:artisan.blog.csdn.net/article/details/73457016
        【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
            cloudbbs@huaweicloud.com
        
        
        
        
        
        
        - 点赞
 - 收藏
 - 关注作者
 
            
 
           
评论(0)