ubuntu 脚本sh编写

常用

# 查看所有环境变量 - 打印环境变量
env
echo $PATH
export LD_LIBRARY_PATH=$PWD
 
#定义和取消变量
var1="123"
unset var1
 
# 打印系统信息 grep -v "U" 反向不匹配
uname -a
 
# 账号和密码 - 切换账号 - 设置账号密码
su root
su -
sudo passwd root
 
# 打开文件管理器 - 切换到用户目录 - 切换到上次访问目录
cd 
cd -
nautilus .
 
# 目录快速操作 目录入栈 出栈 列出栈目录 切换目录 弹出指定栈中目录
# + 从左至右 - 从右至左  序号从0开始计数
pushd .
popd  
dirs
pushd -0
popd +2
 
# 查看命令位置
which git

基本命令详情

# echo 显示文本
# -e 激活转义字符,不当字符串输出
echo "\nHello"
echo "\nHello\b1"
 
# yes 重复输出字符串
yes 
yes n
 
# 创建目录和删除文件
mkdir  dir
rm -rf dir
 
# 复制 符号链接+d参数
# 复制 目录+r参数
cp -df  libdtypestd.so  ..
cp -r   skia ..

其他

# 文件所在目录 相对或者绝对路径
aa=`dirname $0`
 
# 执行脚本文件名
aa=`dirname $0 .sh`
 
# 执行脚本文件名(加后缀)
aa=`dirname $0`
 
# 标准获取脚本所在绝对目录
# 直接执行脚本,启动另一个shell,初始化$0,如$0为./build/copy_std.sh
build_dir=$(cd $(dirname $0);pwd) 
# 即使在source *.sh也正常,source并不会另起一个新的shell进程,推荐写法
build_dir=$(cd $(dirname ${BASH_SOURCE[0]});pwd) 

控制语句

分支控制if

# 单分支 
a=4
if [ $a -eq 4 ]
then
   echo "4 == 4"
fi
 
# 双分支
# -e 文件存在
# -d 是否为目录
# -r 可读 -w 可写 -x 可执行
# 注意[]内部两边有空格
if [ ! -e TextEngineLib ];then
    echo "TextEngineLib not exist"
else
    echo "TextEngineLib exist "
fi
 
# 多分支
if [];then
   echo "1"
elif [];then
   echo "2"
else
   echo "3"
fi

循环控制for

# 执行6次循环
for((i=0;i<6;++i))
do
    echo $i
done
# 另一种方式
for i in {2..7}
do
    echo $i
done
 
# 给定列表循环
for file in a.so b.so c.so 
do 
    echo $file 
done 
 
# 文件
for file in *.txt
do 
    echo $file
done
# 
for file in `ls *.txt`
do 
    echo $file
done

常见脚本写法

获取运行目录,脚本目录,上级目录

#!/bin/bash
run_dir=${PWD} 
build_dir=$(cd $(dirname ${BASH_SOURCE[0]});pwd) 
cd ${build_dir}/.. 
root_dir=${PWD} 
echo $run_dir 
echo $build_dir 
echo $root_dir 
cd $run_dir 

原文:https://blog.csdn.net/dadan1314/article/details/86627770

我们在使用Ubuntu系统开发的过程中,经常会遇到一些重复的操作,想copy, push等等。这个时候我们就可以自己编写一个sh脚本,使用sh脚本操作这些重复的动作。
1.在编写sh脚本前了解一下基本语法
1.1 if语句

#!/bin/sh
myPath="/var/log/httpd/"
myFile="/var/log/httpd/access.log"
-x 判断 m y P a t h 是 否 存 在 并 且 是 否 具 有 可 执 行 权 限 i f [ − x " myPath是否存在并且是否具有可执行权限 if [ -x " myPathif[x"myPath" ];then
#mkdir “$myPath”
echo $myPath
fi

-d 判断 m y P a t h 是 否 存 在 i f [ − d " myPath是否存在 if [ -d " myPathif[d"myPath" ];then
#mkdir “$myPath”
echo $myPath
fi

-f 判断 m y F i l e 是 否 存 在 i f [ − f " myFile是否存在 if [ -f " myFileif[f"myFile" ];then
#touch “$myFile”
echo $myFile
fi

-n 判断一个变量是否有值
if [ -n “$myVar” ];then
echo $myVar “is empty”
exit 0
fi

判断两个变量是否相等
if [ “ v a r 1 " = " var1" = " var1"="var2” ];then
echo “$var1 eq v a r 2 " e l s e e c h o " var2" else echo " var2"elseecho"var1 not eq $var2”
fi

1.2 for语法

#!/bin/bash

for ((i =1;i<=5;i++));
do
sleep 1
echo $i
done

  1. 下面我自己写了一些简单的sample
    2.1 扫描指定文件夹下面的so文件

filehead=“so”
index=0
function getAllFileFromDire(){
#echo $1
for f in 1 / ∗ d o i f [ − d " 1/* do if [ -d " 1/doif[d"f" ]
then
getAllFileFromDire f e l i f [ − f " f elif [ -f " felif[f"f" ]
then
name= f s t a r t = f start= fstart={name:0-2:3}
#echo “ s t a r t " i f [ " start" if [ " start"if["start” = “ f i l e h e a d " ] ; t h e n e c h o " filehead" ];then echo " filehead"];thenecho"name”
let index++
fi
fi
done
}

getAllFileFromDire /home/bob/Desktop/Document/1.7.1/out-of-source

echo $index

2.2 对当前目录下面的所有apk文件进行签名,把签名后的文件放到以当前时间为名字的文件夹下面

#!/bin/bash
key=t1S9D21N03nX
out=date '+%Y%m%d_%H%M'
mkdir $out
for f in *.apk
do
echo $f
#echo $key |
java -jar signapk.jar platform.x509.pem platform.pk8 $f o u t / out/ out/f
done

2.3 把制定的文件夹下面的所有扩展名为so的文件copy到制定的位置

date
source_path=/home/…/Desktop/Document/1.9/out-of-source
#source_path=/home/…/Desktop/Document/out-of-source
target_path=/home/…/tftpboot/avs_libs/
filehead=".so"
index=0
function getAllFileFromDire(){
#echo $1
for f in 1 / ∗ d o i f [ − d " 1/* do if [ -d " 1/doif[d"f" ]
then
getAllFileFromDire f e l i f [ − f " f elif [ -f " felif[f"f" ]
then
name= f s t a r t = f start= fstart={name:0-3:3}
#echo “ s t a r t " i f [ " start" if [ " start"if["start” = “ f i l e h e a d " ] ; t h e n e c h o " filehead" ];then echo " filehead"];thenecho"name”
let index++
cp $name $target_path
fi
fi
done
}

getAllFileFromDire $source_path

echo “copy $index librarys to $target_path”

cp $source_path/Integration/test/app $target_path/…/tools/

2.4 抓取当前系统的memory info到指定文件

#sn=$(adb shell getprop ro.boot.serialno)
out=date '+%Y%m%d_%H%M'_meminfo.txt
echo > $out
#echo SN: ${sn} >> $out
echo >> $out
while true
do

date >> $out
#cat /proc/meminfo | grep -E "Mem|Cached|Buffers" >> $out
cat /proc/meminfo >> $out
echo  >> $out
sleep 60

done

原文:https://blog.csdn.net/bogongjie/article/details/83270331

你可能感兴趣的:(ubuntu 脚本sh编写)