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
图片.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!"



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,902评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,037评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,978评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,867评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,763评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,104评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,565评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,236评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,379评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,313评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,363评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,034评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,637评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,719评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,952评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,371评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,948评论 2 341