shell脚本用法
⑴ 如何用xshell编写脚本
1、在编写shell脚本的时候一般会先查询服务器可以使用哪种脚本,并且查看服务器使用的默认脚本方式是哪一种。
⑵ 如何在shell脚本中使用变量
1、linux shell中的变量一般定义格式为:var=value。其中var是变量名称,=是赋值,value是给变量赋的值。比如下面的变量定义。
a=12;
b="helloworld"
2、注意变量名称的第一个字符不可以是数字,但是可以是下划线。如下示例则为非法的变量名。
3、要使用变量的值,在变量前面加上$符号即可。比如下面的示例:
123=123//这是错误的变量名称
_123=123//这是合法的。
⑶ Shell脚本:${...}在字符串中的多种用法
1、${var}
限定变量。
如果一个变量名A是另一个变量名AB的前部分,那么,如果要在AB相连时,要得到A的值,就必须使用${var}限定。
如果变量名不会产生歧义时(即独立的变量名),${var}与$var没有任何区别。
var="hello"
var_01="hello01"
echo $var $var_01 ${var}_01
>>> hello hello01 hello_01
2、${#var}
得到变量var的长度
var="hello"
echo ${#var}
>>> 5
3、${var#}
删除变量首部的字符(串),
"#"后面的可以是字面串,也可以是正则表达式(惰性匹配)。
var="hello"
echo ${var#he}
>>> llo
var="/res_pos/path/from/something"
echo ${var#/}
>>> res_pos/path/from/something # 删除第一个"/"
echo ${var#/*/}
>>> path/from/something # 删除首部匹配"/*/"的串,即"/res_pos/"
4、${var##}
删除变量首部的字符(串),
只是,当使用2个"##"时,匹配是贪婪的(贪婪匹配,也就是尽可能多的匹配)。
echo ${var##/*/}
>>> something # 删除首部匹配"/*/"的串,即"/res_pos/path/from/"。
5、${var%}
删除变量尾部的字符(串),
"%"后面的可以是字面串,也可以是正则表达式(惰性匹配)。
var="hello"
echo ${var%llo}
>>> he
var="~/res_pos/path/from/something"
echo ${var%/*}
>>> ~/res_pos/path/from # 删除尾部的"/something"
6、${var%%}
删除变量尾部的字符(串),
只是,当使用2个"%%"时,匹配是贪婪的(对应于第4条)
var="~/res_pos/path/from/something"
echo ${var%/*}
>>> ~ # 删除第一个的"/"后的所有所有内容(包括"/"),贪婪匹配中,"/*"就是"/"后的所有字符串
7、${var::}
跟python的切片概念相似,取变量var的起始索引,
指定长度的子串(${var:索引:长度})。
var="~/res_pos/path/from/something"
echo ${var:0:5}
>>> ~/res
echo ${var:1:5}
>>> /res_ # 可见,字符串的索引是从0开始的
echo ${var::5}
>>> ~/res # 省略"索引",默认为从0开始
echo ${var:1:}
>>> # 省略"长度",默认长度为0,所以输出为空
8、${var//}
字符串替换。
将var中的字符串A替换成字符串B(${var/A/B})。
var="hello world"
echo ${var/hello/hi}
>>> hi world # 字符串"hello"替换成了"hi"
echo ${var/l/X}
>>> heXlo world # 第一个"l"替换成了"X"
9、${var///}
字符串替换,
与第8点相同,只不过,现在是将所有出现的串A替换成串B(${var//A/B})。
var="hello world"
echo ${var//l/X}
>>> heXXo worXd # 所有的"l"都替换成了"X"
10、${var/#/}
替换字符串首部的串A为串B,
(${var/#A/B}),与第8点不同的是,这里只替换首部的串A。
var="hello world. hello baby."
echo ${var//h/H}
>>> Hello world. Hello baby. # 将所有"h"替换成了"H"
echo ${var/#h/H}
>>> Hello world. hello baby. # 将首部的"h"替换成了"H"
echo ${var/e/E}
>>> hEllo world. hello baby. # 将第一个出现的"e"替换成了"E"
echo ${var/#e/E}
>>> hello world. hello baby. # 首字符不是"e",所以没有进行任何替换,原样输出。
11、${var/%/}
替换字符串尾部的串A为串B,
(${var/%A/B}),与第10点相似,只是这是处理的是字符串尾。
var="hello hello"
echo ${var/%o/END}
>>> hello hellEND # 将尾部的字符"o",替换成了"END"。
⑷ shell脚本read命令的用法
read命令是读取用户在键盘上输入的信息,然后赋值到一个变量中;read命令是最常用的一个命令,它主要有三个参数,我们一个一个的讲解;
最基本用法:
echo-n "输入你的姓名:"
read name
echo "你的姓名$name"
echo后面的-n是指不换行,应为echo默认是换行的;
--------------------------------------------------------------------------
read -p用法
它的作用是在使用read的命令行是可以直接指定一个提示,例如
read -p "输入你的姓名" name
也就是把echo省略掉了;
-----------------------------------------------------------------------------
read -t用法
使用read命令后,如果你不在键盘上输入一个信息,那系统会一直等待着你的输入,而-t的用法就相当于计时器的作用,几秒中内要是没有输入信息,那read命令便不会再等下去;
read -t 5 -p "在五秒内输入你的姓名" name
-----------------------------------------------------------------------------
read -s用法
隐藏输入的值,就是在键盘上输入密码这一类的保密数据时不实时的显示出来;
⑸ shell脚本中数组的基本用法
首先要告诉大家,Bash Shell 只支持一维数组,而且初始化的时候不用定义数组的大小。
(一) 定义数组,方法1:使用小括号赋值
array1=(A B C D)或者array1=("A" "B" "C" "D")
定义数组,方法2:使用数组下表挨个赋值
array2[0]=a
array2[1]=b
可能会有朋友会问问什么不用declare声明也能用,在这跟大家拓展下,所有变量不用显式定义都能用作数组,所以用不用declare声明都可以
(二) 读取数组
${array[下标值]},例如:${array1[2]}
若要获取数组中全部的值,使用${array[*]}或者${array[@]}
(三) 获取数组长度 ${#array1[*]},关键在加了个#
(四) 删除数组内容元素 unset ${array1[下标]} ,删除整个数组 unset array1
⑹ shell脚本
Shell脚本基本知识
概述:shell其实是内核与用户之间的一个接口,
shell脚本
如果有一系列经常使用的linux命令,你可以把它们存储在一个文件肿。shenll可以读取这个文件,并执行其中的命令。这样的文件成为脚本文件。
执行shell脚本
要创建一个shell脚本,你要使用任何编辑器比如vi在文本文件中编写他。
为了使用bashshell赖执行脚本magic,其命令是:bashmagic或者./magic
echo命令:
echo“!”
屏幕上就会回显“!”
#符号
用于在shell脚本肿可以包含注解入口
echo“hello”
#thisisacommentline.thiswouldnotproceanyoutput!
echo“world!”
第二行是一个注解的例子。它将被shell忽略,而且不产生任何消息
变量:
可以在任何时间通过简单的赋值来创建。
语法:
<variablename>-<value>
Linux中的所有变量都被当作字符串
引用变量:
$符号用于引用一个变量的内容
variable1=${variable2}
读入值给变量
在执行shell脚本时,shell还允许用户直接从键盘读入一个值给变量,还可以使用read命令来作。
$readfname
本地和全局shell变量
局部变量
当引用shell时,只有创建它的shell能够知道变量的存在
全局变量
称为子shell
shell中创建的变量局部于创建它的shell,除非使用export命令特别指出是全局的。
环境变量:
通过改变这些变量的值,用户能够定制此环境
一些环境变量的例子是HOME,PATH,PS1,PS2,LOGNAME,SHLVL,及SHELL
HOME变量
Linux系统中的每个用户都有一个相关的称作HOME的目录
当一个用户登录后,进入相应的HOME的目录
$echo$HOME
PATH变量
包含一列用冒号定界的目录的路径名字,便于可执行程序的搜索。
PS1变量
PS1(PromptString1)变量包含了shell提示符,$符号
$PS1=“HELLO>”
HELLO>
PS2变量
是为第二个提示符设置值的环境变量
LOGNAME变量
包含用户的注册名字
$echo“${LOGNAME}”
SHLVL变量
该变量包含当前工作的shelllevel
SHELL变量
环境变量存储了用户缺省的shell
env命令
可用来查看所有的已移出的环境变量表和它们各自的值!
命令替换
在单个命令行中使用多个命令的另外一种方法(非Pipes)是通过命令替换
echo“thedatais`date`”
expr命令
用于求之算术表达式。该命令的输出被送到标准输出
$expr4+5
将在屏幕上显示9
算术展开:
你可以在$((…))中括一个表达式,用下面的命令来计算它的值;
$((expression))
example1
编写一个shell脚本用于计算呼叫中心未应答的询问的数量。该脚本应该接受一天那所报告的询问的总数和应答的询问的数量,以便计算未应答的询问的数量。
所有未应答的询问总数=所有询问的总数-应答的询问的数量
<!--[if!supportLists]-->※<!--[endif]-->※※※※※※※※※※※※※※※※※※※※※※※
条件执行
test和[]
求值表达式,并返回true(0)或false()
数值测试:
-eq等于则为真
-ne不等于则为真
-gt大于则为真
-ge大于等于则为真
-lt小于则为真
-le小于等于则为真
if构造
Linuxshell提供了循环和判定的构造,可以在shell脚本中使用
算术测试
结合if构造,它可以用于测试变量的数字值
串测试
test命令也可以用于字符串
=等于则为真
!=不相等则为真
-z字符串长度为零则为真
-n字符串长度不为零则为真
文件测试
test命令也可以用于检查文件的状态
-e文件存在则为真
-r文件存在并且可读则为真
-w文件存在并且可写则为真
-x文件存在并且可执行则为真
-s文件存在并且至少有一个字符则为真
-d文件存在并且为目录则为真
-f文件存在并且为普通文件则为真
-c文件存在并且为字符型文件则为真
-b文件存在并且为块特殊文件则为真
-a并且-o或者!非
exit命令
用于终止shell脚本的执行并返回到$提示符下
case。。。esac
shell脚本中使用的这个构造依据变量的值而执行一组特定指令
当变量的值和其中的一个值匹配的时候,就执行写在该值下的一组命令。
example3
迭代
while构造
while<条件>
do
<命令(s)>
done
只有条件为真的时候,才能执行do与done之间的命令
until构造
until循环构造的求值模式于while循环相反
until循环将继续执行直到求值的条件为真的时候
for构造
forvariable_namein<list_of_values>
do
…
done
for循环取一列值作为输入并对循环中每个值执行循环
break和contineu命令
同其他语言中的用法
example4
控制进程的执行
请求后台处理
用于请求后台进程的符号是(&)
$wctempfile&
[1]2082
$vinewfile
检查后台进程
ps(进程状态)命令为每个当前的活动的每个进程产生一行入口。
终止后台进程
可用kill,如下所示
kill278
查看完成一个命令所花的时间
你可以使用time命令来查看一个命令从开始到结束所花的时间
timefine/etc–name“passwd”2>/dev/null/dev/null表明忽略错误信息。
管道的介绍
垂直条(|)是管道字符
它只是shell:“|”前面命令的输出作为“|”之后命令的输入发送
ls–l|more
用管道组合命令,功能强大