shell 脚本

需求是这样的:那么今天闲着想把脚本弄得更自(无)动(脑)化(懒),shell脚本后带参数执行,其中参数的个数不确定(包含列表),而现在脚本模块需要获取传入的倒数第2个参数和除倒数第一个参数外的全部参数,不想用循环列出来,想用类似python的切片方式,所以今天就跟这有关系的awk、shell数组、字符输出和特殊变量磕上了。shell也能好好玩......

实例:/bin/bash script.sh "1001 1002 1003 1004 1005" 1 , 脚本里面要赋值给变量a=1005 , b="1001 1002 1003 1004"

#!/bin/bash

function A(){

    a=${!#}

    b=${@:1:$#-1}

}

A $1
shell 脚本_第1张图片
图片.png

一开始模糊了shell的数组概念,想通过数组实现的,所以也归纳一下数组、变量字符输出以及特殊字符用法:

首先要知道shell数组是以什么形式展现的~

数值类型的数组:一对括号表示数组,数组中元素之间使用“空格”来隔开。

arr_num=(5 4 3 2 1)

字符串类型数组:同样,使用一对括号表示数组,其中数组中的元素使用双引号或者单引号包含,同样使用“空格”来隔开。

arr_str=('aaa' 'bbb' 'ccc')

数组操作:

先赋值一个数组 arr_num=(5 4 3 2 1)

获取数组长度:len=${#arr_num[@]}

读取第一个参数:a=${arr_num[0]}

给第一个参数赋值(会覆盖):arr_num[0]=1

echo ${arr_num[@]} >>> (1 4 3 2 1)

赋值给一个新参数会追加到数组后面:arr_num[10]=9 arr_num[8]=0

echo ${arr_num[@]} >>> (5 4 3 2 1 0 9)

删除第一个参数:unset arr_num[0]

分片(获取第2到第4个参数):${arr_num[@]:1:3}

替换:${arr_num[@]/1/55}

echo ${arr_num[@]} >>> (5 4 3 2 55)


shell的字符输出

假设有变量 test=http://www.baidu.com/haha.html

注:(左边的第一个字符是用 0 表示,右边的第一个字符用 0-1 表示)

1. # 号截取,删除左边字符,保留右边字符。

echo ${test#*//}

其中 test 是变量名,# 号是运算符,*// 表示从左边开始删除第一个 // 号及左边的所有字符

结果:www.baidu.com/haha.html

2. ## 号截取,删除左边字符,保留右边字符。

echo ${test##*/}

*/ 表示从左边开始删除最后(最右边)一个 / 号及左边的所有字符

即删除 http://www.baidu.com/

结果是 haha.html

3.从右边第几个字符开始,及字符的个数

echo ${test:0-9:4}

其中的 0-9 表示右边算起第9个字符开始,4 表示字符的个数。

结果是:haha

4.右边第几个字符开始,一直到结束。

echo ${test:0-9}

表示从右边第9个字符开始,一直到结束。

结果是:haha.html

5.%号截取,删除右边字符,保留左边字符

echo ${test%/*}

%/* 表示从右边开始,删除第一个 / 号及右边的字符

结果是:http://www.baidu.com

6. %% 号截取,删除右边字符,保留左边字符

echo ${test%%/*}

%%/* 表示从右边开始,删除最后(最左边)一个 / 号及右边的字符

结果是:http:


shell的特殊字符

$# 是传给脚本的参数个数

$0 是脚本本身的名字

$1 是传递给该shell脚本的第一个参数

$2 是传递给该shell脚本的第二个参数

$@ 是传给脚本的所有参数的列表

$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个

$$ 是脚本运行的当前进程ID号

$? 是显示最后命令的退出状态,0表示没有错误,其他表示有错误

${!#}输出最后一个参数

假设有变量 var=http://www.aaa.com/123.htm.

1. # 号截取,删除左边字符,保留右边字符。

echo ${var#*``//}

其中 var 是变量名,# 号是运算符,*// 表示从左边开始删除第一个 // 号及左边的所有字符
即删除 http://
结果是 :www.aaa.com/123.htm

2. ## 号截取,删除左边字符,保留右边字符。

echo ${var##*/}

*/ 表示从左边开始删除最后(最右边)一个 / 号及左边的所有字符

即删除 http://www.aaa.com/

结果是 123.htm

3. %号截取,删除右边字符,保留左边字符

echo ${var%/*}
%/* 表示从右边开始,删除第一个 / 号及右边的字符

结果是:http://www.aaa.com

4. %% 号截取,删除右边字符,保留左边字符
echo ${var%%/*}
%%/* 表示从右边开始,删除最后(最左边)一个 / 号及右边的字符
结果是:http:

5. 从左边第几个字符开始,及字符的个数

echo ${var:``0``:``5``}

其中的 0 表示左边第一个字符开始,5 表示字符的总个数。
结果是:http:

6. 从左边第几个字符开始,一直到结束。
echo ${var:``7``}

其中的 7 表示左边第8个字符开始,一直到结束。
结果是 :www.aaa.com/123.htm

7. 从右边第几个字符开始,及字符的个数

echo ${var:``0``-``7``:``3``}

其中的 0-7 表示右边算起第七个字符开始,3 表示字符的个数。
结果是:123

8. 从右边第几个字符开始,一直到结束。

echo ${var:``0``-``7``}

表示从右边第七个字符开始,一直到结束。
结果是:123.htm

注:(左边的第一个字符是用 0 表示,右边的第一个字符用 0-1 表示)

实践:

#!/bin/bash
#---------get more log for system ------
helpFun(){
    echo "Usage: ./test.sh [packagename]...(time)"
    echo "    packagename: you test package name"
    echo "    time: test duration, time units is second"
    echo "./test.sh launcher system_server 3"
    echo "----------------------------------------------------"
}

getTimeFun(){
   #echo "getTimeFun input parameters:"$@
   for paraTimeCount; do true; done

   if [[ $paraTimeCount =~ ^[1-9] ]];
   then
      echo "input parameters timeDuration:${paraTimeCount}s";
   else
      echo "input parameters timeDuration:null, then set timeDuration:10s";
      paraTimeCount=10;
   fi
}

makeDirFun()
{
if [ ! -d "$folder" ]; then
    mkdir "$folder"
else
    rm -rf  $folder
    mkdir "$folder"
fi
}

#above just function, below just start script!
#script start!
helpFun

#init parameters
{
folder="./Use"
makeDirFun
#${!#}--->output last parameter
paraTimeCount=0
paraNum=$#
paraString=$@
}

#print parameters for input
echo "input parameters all :"$paraString
echo "input parameters totalnum:"$paraNum
getTimeFun $paraString

#信息处理
echo "================================================get more log start!"
date
adb shell date >> ./${folder}/Use_all.log
echo "===========pm list package -f|grep =============================" >>  ./${folder}/Use_all.log
adb shell pm list package -f|grep test>> ./${folder}/Use_all.log

{
for((i=1;i<=$paraTimeCount;i++));do
   echo "===========for paraTimeCount===================================="$i

   #******************************************************************************#
   #**************dump all, cpu ,mem ,gpu*****************************************#
   #******************************************************************************#
   #//top -b -d 1 -n 1
   echo "===========top -b -d 1 -n 1==========================================="$i >> ./${folder}/Use_all.log
   `adb shell top -b -d 1 -n 1 > ./${folder}/tempCpuInfo`
   cat ./${folder}/tempCpuInfo >> ./${folder}/Use_all.log;
   
   #//dumpsys meminfo
   `adb shell dumpsys meminfo > ./${folder}/tempMemInfo`
   echo "===========dumpsys meminfo========================================"$i >>  ./${folder}/Use_all.log
   cat ./${folder}/tempMemInfo >> ./${folder}/Use_all.log;
   
   #//gpu_clock
   #echo "===========gpu_clock========================================"$i >>  ./${folder}/nebulaUse_all.log
   #adb shell cat /sys/kernel/gpu/gpu_clock >> ./${folder}/nebulaUse_all.log

   #//gpu_busy_percentage
   #echo "===========gpu_busy_percentage========================================"$i >>  ./${folder}/nebulaUse_all.log
   #adb shell cat /sys/class/kgsl/kgsl-3d0/gpu_busy_percentage >> ./${folder}/nebulaUse_all.log


   #******************************************************************************#
   #*****************dump data, cpu ,mem ,gpu.  other nousing uptime**************#
   #******************************************************************************#
   #//dump cpu all
   adbcmdRes=`cat ./${folder}/tempCpuInfo|grep "%cpu"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_cpu_all.log;

   #//dump mem all
   #dump mem all Total RAM:
   adbcmdRes=`cat ./${folder}/tempMemInfo|grep "Total RAM:"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/nebulaUse_mem_all_TotalRAM.log;
   #dump mem all Free RAM:
   adbcmdRes=`cat ./${folder}/tempMemInfo|grep "Free RAM:"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_mem_all_FreeRAM.log;
   #dump mem all Used RAM:
   adbcmdRes=`cat ./${folder}/tempMemInfo|grep "Used RAM:"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_mem_all_UsedRAM.log;
   #dump mem all Lost RAM:
   adbcmdRes=`cat ./${folder}/tempMemInfo|grep "Lost RAM:"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_mem_all_LostRAM.log;
   #dump mem all ZRAM:
   adbcmdRes=`cat ./${folder}/tempMemInfo|grep "ZRAM:"`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_mem_all_ZRAM.log;
   
   
   #******************************************************************************#
   #***********dump specific packagename app cpu and mem info ********************#
   #******************************************************************************#
   for packagename in ${@:1:$#-1}; do
       echo "----------------------package_name:"$packagename" time="${i}
       tempname=$packagename;
       tempfilename=${tempname//\./\_}

       #//dump cpu using packagename
       adbcmdRes=`cat ./${folder}/tempCpuInfo|grep ${tempname}`
       echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_cpu_$tempfilename.log;

       #//dump mem using packagename
       adbcmdRes=`adb shell dumpsys meminfo ${tempname}|grep TOTAL`
       echo ${adbcmdRes%TOTAL:*}" time="${i} >> ./${folder}/Use_mem_$tempfilename.log
      
       #case $packagename in
          #"launcher")
              #//dump cpu using launcher
              #adbcmdRes=`adb shell top -b -d 1 -n 1|grep "launcher"`
              #echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_cpu_launcher.log;
              #adb shell top -b -d 1 -n 1|grep "launcher" >> ./${folder}/Use_cpu_launcher.log;

              #//dump mem using 
              #adbcmdRes=`adb shell dumpsys meminfo launcher|grep TOTAL`
              #echo ${adbcmdRes%TOTAL:*}" time="${i} >> ./${folder}/Use_mem_launcher.log
              #adb shell dumpsys meminfo launcher >> ./${folder}/nebulaUse_mem_launcher.log
          #;;
       #esac
   done


   #******************************************************************************#
   #***********dump gpu clock and precentageg ************************************#
   #******************************************************************************#
   adbcmdRes=`adb shell cat /sys/kernel/gpu/gpu_clock`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_gpu_clock.log;
   
   adbcmdRes=`adb shell cat /sys/class/kgsl/kgsl-3d0/gpu_busy_percentage`
   echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_gpu_utilize.log;

   #***********dump cpu load average ********************************************#
   #adbcmdRes=`adb shell uptime`
   #echo ${adbcmdRes}" time="${i} >> ./${folder}/Use_cpu_loader.log;

done
}
date
adb shell date >> ./${folder}/Use_all.log

##clean temp files
rm ./${folder}/temp*
echo "==================================================get more log end!"



你可能感兴趣的:(shell 脚本)