调试 shell script 方法

wade@V1088:~$ cat b.sh
#!/bin/bash dir=`pwd` dir=$dir'/' for f in `ls *.png` do echo $dir$f done

看每一行代码的执行:

wade@V1088:~$ bash -x b.sh
++ pwd
+ dir=/home/wade
+ dir=/home/wade/
++ ls chrome_1407299385726.png chrome_1427299385726.png
+ for f in '`ls *.png`'
+ echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+ for f in '`ls *.png`'
+ echo /home/wade/chrome_1427299385726.png

进一步,看具体执行的代码与行号对应:

wade@V1088:~$ export PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
wade@V1088:~$ bash -x b.sh
++b.sh:2:: pwd
+b.sh:2:: dir=/home/wade
+b.sh:3:: dir=/home/wade/
++b.sh:8:: ls chrome_1407299385726.png chrome_1427299385726.png
+b.sh:4:: for f in '`ls *.png`'
+b.sh:7:: echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+b.sh:4:: for f in '`ls *.png`'
+b.sh:7:: echo /home/wade/chrome_1427299385726.png

指定脚本的部分去跑详细的行号,其余的忽略:

wade@V1088:~$ cat b.sh 
#!/bin/bash
dir=`pwd`
dir=$dir'/'
#this line above won't log out 
set -x
for f in `ls *.png`
do

  echo $dir$f
done
set +x
#the follow line won't log out 
echo 'end'
abc='new var'

运行输出:

wade@V1088:~$ ./b.sh
++./b.sh:10:: ls chrome_1407299385726.png chrome_1427299385726.png
+./b.sh:6:: for f in '`ls *.png`'
+./b.sh:9:: echo /home/wade/chrome_1407299385726.png
/home/wade/chrome_1407299385726.png
+./b.sh:6:: for f in '`ls *.png`'
+./b.sh:9:: echo /home/wade/chrome_1427299385726.png
/home/wade/chrome_1427299385726.png
+./b.sh:11:: set +x
end

 

转载于:https://www.cnblogs.com/no7dw/p/3923657.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值