用法: sh start.sh {filter|filter_city|filter_prov|city|prov}
例如: sh start.sh filter 只过滤黑名单
sh start.sh filter_city 先过滤黑名单并分地市
sh start.sh filter_prov 先过滤黑名单并分省
sh start.sh city 只做分地市
sh start.sh prov 只做分省
用到的脚本有filter.sh filter mdn_city.sh mdn_prov.sh start.sh
[oracle@lmailmms filter]$ more start.sh
#!/bin/bash
DATE=`date +%Y_%m_%d_%H_%M_%S`
case "$1" in
filter)
echo "starting filter mdn ..." >> log/log.txt
echo "=======开始过虑黑名单操作`date +%Y-%m-%d_%H:%M:%S`====="
echo "=======开始过虑黑名单操作`date +%Y-%m-%d_%H:%M:%S`=====">>log/log.txt
sh filter.sh
cp users.txt log/users_filter_$DATE.txt
echo "=======过滤黑名单结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果。=====
===">>log/log.txt
echo "=======过滤黑名单结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果。=====
==="
;;
filter_city)
echo "starting filter_city mdn ..." >>log/log.txt
echo "=======开始过虑黑名单并分地市操作`date +%Y-%m-%d_%H:%M:%S`=====
=">>log/log.txt
echo "=======开始过虑黑名单并分地市操作`date +%Y-%m-%d_%H:%M:%S`.====
==="
sh filter.sh
cp users.txt log/users_filter_city_$DATE.txt
mv new.txt users.txt
sh mdn_city.sh
cp log/users_filter_city_$DATE.txt users.txt
echo "===过虑黑名单分地市结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.
======="
echo "===过虑黑名单分地市结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.
=======">>log/log.txt
;;
filter_prov)
echo "starting filter_prov mdn ..." >>log/log.txt
echo "=======开始过虑黑名单并分省操作`date +%Y-%m-%d_%H:%M:%S`============"
echo "=======开始过虑黑名单并分省操作`date +%Y-%m-%d_%H:%M:%S`============">>lo
g/log.txt
sh filter.sh
cp users.txt log/users_filter_prov_$DATE.txt
mv new.txt users.txt
sh mdn_prov.sh
cp log/users_filter_prov_$DATE.txt users.txt
echo "=======过虑黑名单分省结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.==
====="
echo "=======过虑黑名单分省结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.==
=====">>log/log.txt
;;
city)
echo "starting city mdn ..." >>log/log.txt
echo "starting city mdn ..."
echo "========开始分地市操作`date +%Y-%m-%d_%H:%M:%S`==============="
echo "=====开始分地市操作`date +%Y-%m-%d_%H:%M:%S`==================">>
log/log.txt
sh mdn_city.sh
cp users.txt log/users_city_$DATE.txt
;;
prov)
echo "starting prov mdn ..." >>log/log.txt
echo "starting prov mdn ..."
echo "======开始分省操作`date +%Y-%m-%d_%H:%M:%S`==========================="
echo "======开始分省操作`date +%Y-%m-%d_%H:%M:%S`===========================">
>log/log.txt
sh mdn_prov.sh
cp users.txt log/users_prov_$DATE.txt
;;
*)
echo "用法: ./start.sh {filter|filter_city|filter_prov|city|prov}"
exit 1
esac
exit 0
[oracle@lmailmms filter]$ more filter
sqlplus wlblsusr/XXXXXX <set feedback off
set heading off
set pagesize 0
spool new.txt
select * from temp t where not exists (select 1 from wl_bls_blacklist m where m.vc2mdn = t.mdn);
spool off
truncate table temp;
EOF
exit
[oracle@lmailmms filter]$ more filter.sh
#/bin/bash
#DATE=`date +%Y-%m-%d" "%H:%M:%S`
echo "开始过滤黑名单操作`date +%Y-%m-%d" "%H:%M:%S`"
echo "开始过滤黑名单操作`date +%Y-%m-%d" "%H:%M:%S`" >> log/log.txt
#把数据库临时表temp清空。
sqlplus wlblsusr/XXXXXX <truncate table temp;
EOF
if [ -s users.txt ]
then
# sh truncate_temp.sh
dos2unix users.txt > /dev/null 2>&1
sed 's/^86//;s/ *$//' users.txt > users1.txt
sort -n -u users1.txt > users_temp.txt
sqlldr wlblsusr/wlblsusr control=temp.ctl
rm -f new.txt
sh filter
awk '$1 >= 13000000000 && $1 <= 16000000000 ' new.txt > new
sed 's/ *$//' new >new.txt
MDN1=`cat users.txt |wc -l`
MDN2=`cat new.txt |wc -l`
MDN3=`expr $MDN1 - $MDN2 `
echo "过黑前为:$MDN1个号,过完后为:$MDN2个号,过滤掉:$MDN3个号。"
echo "过黑前为:$MDN1个号,过完后为:$MDN2个号,过滤掉:$MDN3个号。" >>log/log.txt
echo "黑名单过滤完成`date +%Y-%m-%d" "%H:%M:%S`." >>log/log.txt
echo "黑名单过滤完成`date +%Y-%m-%d" "%H:%M:%S`."
else
echo "users.txt文件不存在,或users.txt里没有内容。请核对。"
echo "users.txt文件不存在,或users.txt里没有内容。请核对。" >> log/log.txt
fi
rm -f users1.txt users users_temp.txt new
#mv users.txt log/users_filer_`date +%Y_%m_%d_%H_%M_%S`.txt
[oracle@lmailmms filter]$ more mdn_city.sh
#!/bin/bash
#DATE=`date +%Y-%m-%d" "%H:%M:%S`
echo "开始分地市操作`date +%Y-%m-%d" "%H:%M:%S`"
echo "开始分地市操作`date +%Y-%m-%d" "%H:%M:%S`" >> log/log.txt
if [ -s users.txt ]
then
dos2unix users.txt > /dev/null 2>&1
sed 's/^86//;s/ *$//' users.txt > users1.txt
sort -n -u users1.txt > users
awk 'NR==FNR{a[$1]=$4}NR>FNR&&a[b=substr($1,1,7)]{print $1,a[b]}' cwm_mdn_prov users >new
sort -k 2 new > new.txt
awk '{print $2}' new.txt |uniq -c > new_goup.txt
cat new_goup.txt
cat users.txt |wc -l >number
echo "分地市操作完成`date +%Y-%m-%d" "%H:%M:%S`,共操作`cat number`个号码." >> log/log.txt
echo "分地市操作完成`date +%Y-%m-%d" "%H:%M:%S`,共操作`cat number`个号码."
echo "============================分地市结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.======="
echo "============================分地市结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.=======">>log/log.txt
else
echo "users.txt文件不存在,或users.txt里没有内容。请核对。"
echo "users.txt文件不存在,或users.txt里没有内容。请核对。" >> log/log.txt
fi
rm -f new users number users1.txt
[oracle@lmailmms filter]$ more mdn_prov.sh
#!/bin/bash
#`date +%Y-%m-%d" "%H:%M:%S`DATE=`date +%Y-%m-%d" "%H:%M:%S`
echo "开始分省操作`date +%Y-%m-%d" "%H:%M:%S` "
echo "开始分省操作`date +%Y-%m-%d" "%H:%M:%S`" >> log/log.txt
if [ -s users.txt ]
then
dos2unix users.txt > /dev/null 2>&1
sed 's/^86//;s/ *$//' users.txt > users1.txt
sort -n -u users1.txt > users_temp
awk 'NR==FNR{a[$1]=$5}NR>FNR&&a[b=substr($1,1,7)]{print $1,a[b]}' cwm_mdn_prov users_temp >new.txt
sort -k 2 new.txt > new_temp
awk '{print $2}' new_temp |uniq -c > new_goup.txt
cat new_goup.txt
cat users.txt |wc -l >number
echo "分省操作完成`date +%Y-%m-%d" "%H:%M:%S`共操作`cat number`个号码." >> log/log.txt
echo "分省操作完成`date +%Y-%m-%d" "%H:%M:%S`共操作`cat number`个号码."
else
echo "users.txt文件不存在,或users.txt里没有内容。请核对。"
echo "users.txt文件不存在,或users.txt里没有内容。请核对。" >>log/log.txt
echo "============================分省结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.========="
echo "============================分省结束`date +%Y-%m-%d_%H:%M:%S`,new.txt为所要的结果.=========">>log/log.txt
fi
rm -f new_temp users_temp number users1.txt
阅读(2243) | 评论(0) | 转发(0) |