订阅
纠错
加入自媒体

Linux入门:一文帮你搞定shell编程!

2021-05-28 14:51
一口Linux
关注

一、变量的使用

1. 变量命名

定义变量时,变量名不加美元符号($,PHP语言中变量需要),如:

your_name="yikoulinux"

注意,变量名和等号之间不能有空格,这可能和你熟悉的所有编程语言都不一样。同时,变量名的命名须遵循如下规则:

命名只能使用英文字母,数字和下划线,首个字符不能以数字开头。中间不能有空格,可以使用下划线(_)。不能使用标点符号。不能使用bash里的关键字(可用help命令查看保留关键字)。变量名称一般习惯为大写

有效的 Shell 变量名示例如下:

RUNOOB
LD_LIBRARY_PATH
_var
var2

无效的变量命名:

?var=123
user*name=runoob

2. 常用变量

Linux Shell 中的变量分为:系统变量和用户自定义变量。

系统变量:、PWD、、USER 等等比如: echo $HOME 等等..

用户自定义变量:

定义变量:变量=值2)显示当前 shell 中所有变量:set3)撤销变量:unset 变量声明静态变量:readonly 变量,注意:不能 unset将命令的返回值赋给变量(重点)

除了显式地直接赋值,还可以用语句给变量赋值,如:1)A=ls -la反引号,运行里面的命令,并把结果返回给变量 A2)

A=$(ls -la)

$等价于反引号

3)

for file in `ls /etc`

for file in $(ls /etc)

以上语句将 /etc 下目录的文件名循环出来。

3. 举例

例1:

含义如下:

定义一个变量名为name的变量,值为一口linux输出变量name的值定义一个变量名为number的变量,初始值为22输出变量number的值直接输出带变量的字符串使用双引号输出带变量的字符串使用单引号输出带变量的字符串使用双引号输出带不存在的变量的字符串,不存在的变量默认为空使用双引号来声明字符串中的变量使用大括号{&变量名},声明字符串中的变量

注意:上述变量是临时变量,当关闭终端后,变量就会消失。

例2:删除变量并查看指定变量

unset name  删除变量name查看name变量

二、字符串的操作

在做shell批处理程序时候,经常会涉及到字符串相关操作。有很多命令语句,如:awk,sed都可以做字符串各种操作。

其实shell内置一系列操作符号,可以达到类似效果,大家知道,使用内部操作符会省略启动外部程序等时间,因此速度会非常的快。

1. 字符串操作(长度,读取,替换)表达式含义
${#string}$string的长度${string:position}在 中从位置position开始提取子串${string:position:length}在中从位置position开始提取长度为$length的子串${string#substring}从变量的开头删除最短匹配substring的子串${string##substring}从变量的开头删除最长匹配substring的子串${string%substring}从变量的结尾删除最短匹配substring的子串${string%%substring}从变量的结尾删除最长匹配substring的子串${string/substring/replacement}使用来代替第一个匹配的substring${string//substring/replacement}使用代替所有匹配的substring${string/#substring/replacement}如果的前缀匹配substring, 那么就用来代替匹配到的substring${string/%substring/replacement}如果的后缀匹配substring, 那么就用来代替匹配到的substring

说明:"* $substring”可以是一个正则表达式.

2. 字符串操作举例

a) 计算字符串长度

root@ubuntu:/home/peng# test='I love china'
root@ubuntu:/home/peng# echo ${#test}
12

${#变量名}得到字符串长度

b) 截取字串

root@ubuntu:/home/peng# test='I love china'
root@ubuntu:/home/peng# echo ${test:5}
e china
root@ubuntu:/home/peng# echo ${test:5:10}
e china
root@ubuntu:/home/peng#
root@ubuntu:/home/peng# echo ${test:4:10}
ve china

${变量名:起始:长度}得到子字符串

c) 字符串删除

root@ubuntu:/home/peng# test='c:/windows/boot.ini'
root@ubuntu:/home/peng# echo ${test#/}
c:/windows/boot.ini
root@ubuntu:/home/peng# echo ${test#}
windows/boot.ini
root@ubuntu:/home/peng# echo ${test##}
boot.ini
root@ubuntu:/home/peng# echo ${test%}
c:/windows
root@ubuntu:/home/peng# echo ${test%%}
c:

${变量名#substring正则表达式}从字符串开头开始配备substring,删除匹配上的表达式。
${变量名%substring正则表达式}从字符串结尾开始配备substring,删除匹配上的表达式。

注意:

${test##},${test%} 分别是得到文件名,或者目录地址最简单方法。

d) 字符串替换

root@ubuntu:/home/peng# test='c:/windows/boot.ini'
root@ubuntu:/home/peng# echo ${test///\}
c:windows/boot.ini
root@ubuntu:/home/peng# echo ${test////\}
c:windowsoot.ini

${变量/查找/替换值} 一个“/”表示替换第一个,”//”表示替换所有,当查找中出现了:”/”请加转义符”/”表示。

注意:字符串的位置是从0开始,-1表示该字符串最后一个位置;截取字符串的时候,是左闭右开的,从左边的位置开始,一直到右边的位置结束,不包括右边的位置。

三、 脚本的创建和执行

shell脚本并不能作为正式的编程语言,因为它是在Linux的shell中运行的,所以称他为shell脚本。事实上,shell脚本就是一些命令的集合。我们通常把所有的操作都记录到一个文档中,然后去调用文档中的命令,这样一步操作就可以完成了一般shell脚本都是放在/usr/local/sbin的目录下。

1) shell脚本的建立

在linux系统中,shell脚本(bash shell程序)通常是在编辑器(如vi/vim)中编写,由unix/linux命令、bash shell命令、程序结构控制语句和注释等内容组成,推荐用vim编辑器。

2) 脚本开头(第一行)

一个规范的shell脚本的第一行会指出由哪个程序(解释器)来执行脚本中的内容,在linux bash编程中一般为:

#!/bin/bash

#!/bin/sh  <==255个字符以内

其中开头的"#!"又称为幻数,在执行bash脚本的时候,内核会根据"#!"后的解释器来确定该用哪个程序解释脚本中的内容,注意:这一行必须在每个脚本顶端的第一行,如果不是第一行则为脚本注释行,例如下面的例子。

root@ubuntu:/home/peng# cat test1.sh
#!/bin/bash
echo "scajy start"
#!/bin/bash      <==写到这里就是注释
#!/bin/sh
echo "scajy en:"

sh和bash的区别

root@ubuntu:/home/peng# ls -l /bin/sh
lrwxrwxrwx 1 root root 4 Sep 21  2015 /bin/sh -> bash

提示:sh为bash的软连接,这里推荐用标准写法#!/bin/bash

Bash是GNU/Linux默认的shell,和Bourne shell (sh)兼容,Bash采用了Korn shell (Ksh)和C shell(csh)的特色。符合IEEE POISIX P10003.2/ISO 9945.2 shell and tools 标准。

Centos和redhat linux 下默认的shell 均为bash 因此,在写shell脚本的时候,我们的脚本的开头也可以不加#!/bin/bash。但如果当前的shell非你默认的shell时,比如tcsh,那么久必须要写#!了。否则脚本文件就只能执行一些命令的集合,不能够使用shell内建的指令了,建议读者养成习惯,不管什么脚本最好都加上开头语言标识,这在后文的shell编程规范中会再次提到。如果脚本的开头不指定解析器,那么,就要用对应的解释器来执行脚本。例如:bash test.sh

3) 脚本注释

在shell脚本中,跟在(#)#号后面的内容表示注释,用来对脚本进行注释说明,注释部分不会被执行,仅仅是给人看的,注释可自一行,也可以跟在脚本命令后面与命令在同一行,开发脚本时,如果没有注释,其他人就很难理解脚本究竟在做什么,时间长了自己也会忘记。因此,我们要尽量成为所做的工作(脚本等)书写注释的习惯,不光是方便别人,也是方便自己。否则写完一个脚本后也许后就记不起脚本的用途了,在重新阅读也会浪费很多宝贵时间。对于团队的协作也不利。

4) 举例

创建文件first.sh,并拷贝如下信息到文件:

#cd usr/local/sbin
# vim first.sh
#! /bin/bash
##this is my first shell script
#wirten by 一口Linux 2021.5.3
date
echo "Hello world"

shell脚本通常以.sh为后缀名

执行脚本以下几种方法都可以:

#sh first.sh
#bash first.sh
#./first.sh
#./first.sh

会报权限不够可以:

#chmod +x first.sh

1  2  3  下一页>  
声明: 本文由入驻维科号的作者撰写,观点仅代表作者本人,不代表OFweek立场。如有侵权或其他问题,请联系举报。

发表评论

0条评论,0人参与

请输入评论内容...

请输入评论/评论长度6~500个字

您提交的评论过于频繁,请输入验证码继续

暂无评论

暂无评论

文章纠错
x
*文字标题:
*纠错内容:
联系邮箱:
*验 证 码:

粤公网安备 44030502002758号