【第一个】

#!/bin/bash
#每个用户的总充值和消费以及剩余。

cat yuanbao.txt |grep -v 2016 |awk '{print $3}' |awk '!a[$0]++' >user.list #把用户名去重后添加到一个文件里

cat /dev/null > all.log

while read user
do
buy=`cat yuanbao.txt |grep $user |awk '{print $7}' |awk '{sum += $1};END {print sum}'` #取出所以第7列的总值
now=`cat yuanbao.txt |grep $user |awk 'END{print $9}'` #取出每个用户第9列的最后一行的值
zong=$((buy-now)) #总充值减去剩余的

echo "用户 $user 总充值 $buy 已消费 $zong 剩余 $now" >> all.log

done < user.list

【第二个】

#!/bin/bash
#每个用户每一天的充值buy总和
cat /dev/null > day.log

#NOW=date +%Y-%m
while read user
do
for ((i=1;i<=366;i++))
do
NOW=`date +%F`
SHIJIAN=`date -d "2013-12-31 +$i day" +%Y-%m-%d`
if [ ${SHIJIAN} = ${NOW} ]; then
break
fi
cat yuanbao.txt |grep $SHIJIAN |grep $user &>/dev/null
if [ $? -eq 0 ] ; then
BUY=`cat yuanbao.txt |grep $SHIJIAN |grep $user |awk '{print $7}' |awk '{sum += $1};END {print sum}'`
echo "$SHIJIAN 账号 $user 每一天buy总 $BUY" >> day.log
fi
done
done < user.list

【第三个】

#!/bin/bash
#每个用户每个月的充值总和
cat yuanbao.txt |grep -v 2016 |awk '{print $3}' |awk '!a[$0]++' >user.list #把用户名去重后添加到一个文件里
cat /dev/null > month.log

while read user
do
for ((i=1;i<=50;i++))
do
NOW=`date +%Y-%m`
SHIJIAN=`date -d "2013-12-01 +$i month" +%Y-%m`
if [ ${SHIJIAN} = ${NOW} ]; then
break
fi

cat yuanbao.txt |grep $SHIJIAN |grep $user &>/dev/null
if [ $? -eq 0 ] ; then
BUY=`cat yuanbao.txt |grep $SHIJIAN |grep $user |awk '{print $7}' |awk '{sum += $1};END {print sum}'`
echo "$SHIJIAN 账号$user buy总和$BUY" >> month.log
fi
done
done < user.list

#cat month.log.bak | grep 'buy总和" "' > month.log

【第四个】

#!/bin/bash
#每一天所有用户的buy总和

cat /dev/null > day.log
NOW=`date +%F`
for ((i=1;i<=1000;i++))
do
SHIJIAN=`date -d "2013-12-31 +$i day" +%Y-%m-%d`
if [ ${SHIJIAN} = ${NOW} ];then
break
fi
cat yuanbao.txt |grep $SHIJIAN &>/dev/null
if [ $? -eq 0 ] ; then
ZHI=`cat yuanbao.txt |grep $SHIJIAN |awk '{print $7}' |awk '{sum += $1};END {print sum}'`
echo "$SHIJIAN daily sum $ZHI" >> day.log
fi
done

【第五个】

#!/bin/bash
#每月所有用户的充值总和
cat /dev/null > month.log
NOW=`date +%Y-%m`
for ((i=1;i<=1000;i++))
do
SHIJIAN=`date -d "2013-12-01 +$i month" +%Y-%m`
if [ ${SHIJIAN} = ${NOW} ];then
break
fi
#cat yuanbao.txt |grep $SHIJIAN &>/dev/null
#if [ $? -eq 0 ] ; then
ZHI=`cat yuanbao.txt |grep $SHIJIAN |awk '{print $7}' |awk '{sum += $1};END {print sum}'`
echo "$SHIJIAN 每月所有用户充值总和是:$ZHI" >> month.log
#fi
done

Shell 脚本练习的更多相关文章

  1. 第一个shell脚本

    打开文本编辑器,新建一个文件,扩展名为sh(sh代表shell),扩展名并不影响脚本执行,见名知意就好. #!/bin/bash echo "Hello World !" &quo ...

  2. 使用C#给Linux写Shell脚本

    在这个逼格决定人格,鄙视链盛行的年头,尤其是咱们IT界,请问您今天鄙视与被鄙视的次数分别是多少?如果手中没有一点压箱的本事,那就只有看的份了.今天我们也要提升下自己的格调,学习些脑洞大开的东西,学完之 ...

  3. shell脚本规划化模板

    shell脚本规划化模板 Linux运维过程中,shell脚本是不可缺少的工具,但是每个运维人员编程的习惯都不一样,很多时候就是实现某个功能,写出来的脚本都是烂七八糟的.脚本必须规范化,应该从以后几个 ...

  4. Shell脚本编程30分钟入门

    Shell脚本编程30分钟入门 转载地址: Shell脚本编程30分钟入门 什么是Shell脚本 示例 看个例子吧: #!/bin/sh cd ~ mkdir shell_tut cd shell_t ...

  5. Linux Shell脚本逻辑操作符简介

    在写程序时,会用到条件判断,测试条件是否成立.很多时候,判断条件是多个的,这个时候需要用到逻辑操作符.shell脚本中常用的有哪些逻辑操作符呢? 1.逻辑与: -a 格式: conditon1 -a ...

  6. Linux shell脚本编程(三)

    Linux shell脚本编程 流程控制: 循环语句:for,while,until while循环: while CONDITION; do 循环体 done 进入条件:当CONDITION为“真” ...

  7. Linux shell脚本编程(二)

    Linux shell脚本编程(二) 练习:求100以内所有偶数之和; 使用至少三种方法实现; 示例1: #!/bin/bash # declare -i sum=0 #声明一个变量求和,初始值为0 ...

  8. Linux shell脚本编程(一)

    Linux shell脚本编程: 守护进程,服务进程:启动?开机时自动启动: 交互式进程:shell应用程序 广义:GUI,CLI GUI: CLI: 词法分析:命令,选项,参数 内建命令: 外部命令 ...

  9. 详解Linux交互式shell脚本中创建对话框实例教程_linux服务器

    本教程我们通过实现来讲讲Linux交互式shell脚本中创建各种各样对话框,对话框在Linux中可以友好的提示操作者,感兴趣的朋友可以参考学习一下. 当你在终端环境下安装新的软件时,你可以经常看到信息 ...

  10. shell 脚本之循环使用 for while 详解

    任何一种编程语言中循环是比不可少的,当然 shell 脚本也少不了循环语句,包括 for 语句. while 语句.文中主要以实际用例来说明 for while 都有哪些常见的使用方法和技巧. 一.f ...

随机推荐

  1. Java基础总结1

    数据类型: byte    1字节 short   2字节 int        4字节 long     8字节 float     4字节 double   8字节 char       2字节 ...

  2. Linux 开放端口号(mysql开启远程连接)

    在 Centos 7 或 RHEL 7 或 Fedora 中防火墙由 firewalld 来管理,而不是 iptables. 一.firewalld 防火墙语法命令如下:启用区域端口和协议组合 fir ...

  3. 自制操作系统Antz(7)——实现内核 (上)

    Antz系统更新地址: https://www.cnblogs.com/LexMoon/category/1262287.html Linux内核源码分析地址:https://www.cnblogs. ...

  4. mysql批量查询

    一般批量查询的时候都是in关键字,但是在数据量大的时候,效率低下. 这个时候我们就可以考虑使用union . xml 核心代码 <select id="selectList" ...

  5. opencv学习之路(35)、SURF特征点提取与匹配(三)

    一.简介 二.opencv中的SURF算法接口 三.特征点匹配方法 四.代码 1.特征点提取 #include "opencv2/opencv.hpp" #include < ...

  6. 利用matplotlib库和numpy库画数学图形

    首先,电脑要安装到matplotlib库和numpy库,这可以通过到命令符那里输入“pip install matplotlib ”,两个操作一样 其次,参照下列代码: import numpy as ...

  7. Codeforces 1027F Session in BSU - 并查集

    题目传送门 传送门I 传送门II 传送门III 题目大意 有$n​$门科目有考试,第$i​$门科目有两场考试,时间分别在$a_i, b_i\ \ (a_i < b_i)​$,要求每门科目至少参加 ...

  8. mysql配置外部允许外部连接

    1. 登录到mysql mysql -u root -p 2.进入到mysql 库中 use mysql 3.执行语句 update user set host=‘%’ where user=‘roo ...

  9. 清华源和中科大源都停止对Anaconda的支持之后,换腾讯云镜像的方法

    直接下载下面的文件解压后放在用户文件夹下即可,windows为"C:\用户\你的用户名\",Linux为"/home/你的用户名/"即用户主目录下. 点我下载 ...

  10. sed命令替换文件的内容【学习笔记】

    sed -i "s/line/Line/g" `grep "line" -rl /home//zhuangzebin/`