需求是这样的:那么今天闲着想把脚本弄得更自(无)动(脑)化(懒),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的数组概念,想通过数组实现的,所以也归纳一下数组、变量字符输出以及特殊字符用法:
首先要知道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!"