shell脚本之变量、运算、条件测试。

概述

程序:指令+数据

程序编程风格:

过程式:以指令为中心,数据服务于指令

对象式:以数据为中心,指令服务于数据

shell程序:提供了编程能力,解释执行

计算机:运行二进制指令;

编程语言:

低级:

            汇编

高级:

            编译:高级语言–>编译器–>目标代码 java,C#

            解释:高级语言–>解释器–>机器代码 shell, perl, python

编程逻辑处理方式:

        顺序执行

        循环执行

        选择执行

shell编程:

        过程式、解释执行

编程语言的基本结构:

        数据存储:

        变量、数组 表达式: a + b

        语句:if

shell脚本是包含一些命令或声明,并符合一定格式的文 本文件

格式要求:首行shebang机制

        #!/bin/bash

        #!/usr/bin/python

        #!/usr/bin/perl

shell脚本的用途有:

        自动化常用命令

        执行系统管理和故障排除

        创建简单的应用程序

        处理文本或文件

bash -n /path/to/some_script 检测脚本中的语法错误
bash -x /path/to/some_script 调试执行

 变量命名法则:

        1、不能使程序中的保留字:例如if, for;

        2、只能使用数字、字母及下划线,且不能以数字开头

        3、见名知义

        4、统一命名规则:驼峰命名法

变量的种类;

 根据变量的生效范围等标准:

本地变量:生效范围为当前shell进程;对当前shell之外 的其它shell进程,包括当前shell的子shell进程均无效

环境变量:生效范围为当前shell进程及其子进程 局部变量:生效范围为当前shell进程中某代码片断(通常 指函数) 位置变量:$1, $2, …来表示,用于让脚本在脚本代码 中调用通过命令行传递给它的参数 特殊变量:$?, $0, $*, $@, $#。

本地变量

变量赋值:name=‘value’,

可以使用引用value:

        (1) 可以是直接字串; name=“root"

        (2) 变量引用:name="$USER"

        (3) 命令引用:name=`COMMAND`, name=$(COMMAND)

变量引用:${name}, $name "":

        弱引用,其中的变量引用会被替换为变量值 '':

        强引用,其中的变量引用不会被替换为变量值,而保 持原字符串

显示已定义的所有变量:set

删除变量:unset name

环境变量

变量声明、赋值: export name=VALUE declare -x name=VALUE

变量引用:$name, ${name}

显示所有环境变量: export env printenv

删除:unset name

bash有许多内建的环境变量:PATH, SHELL, USRE,UID, HISTSIZE, HOME, PWD, OLDPWD, HISTFILE, PS1

位置变量

只读变量:只能声时,但不能修改和删除 readonly name declare -r name

位置变量:在脚本代码中调用通过命令行传递给脚本的参数

            $1, $2, …:对应第1、第2等参数,shift [n]换位置

            $0: 命令本身

            $*: 传递给脚本的所有参数,全部参数合为一个字符串

            $@: 传递给脚本的所有参数,每个参数为独立字符串

            $#: 传递给脚本的参数的个数

            $@ $* 只在被双引号包起来的时候才会有差异

             相同点:都是引用所有参数
             不同点:只有在双引号中体现出来
            假设你的脚本运行时你写了三个参数 分别存储在$1 $2 $3中
            则"$*" 等价于 “$1 $2 $3"  —》传递了一个参数
            而“$@" 等价于 "$1"  "$2"  "$3"   —》传递了三个参数

示例:判断给出的文件的行数 linecount="$(wc -l $1| cut -d' ' -f1)" echo "$1 has $linecount lines."

bash中的算术运算:

help let +, -, *, /, %取模(取余), **(乘方) 实现算术运算:

            (1) let var=算术表达式

[root@centous1 ~]# let var1=1+2
[root@centous1 ~]# echo $var1
3

            (2) var=$[算术表达式]

[root@centous1 ~]# var2=$[2+3]
[root@centous1 ~]# echo $var2
5

            (3) var=$((算术表达式))

[root@centous1 ~]# var3=$((3+4))
[root@centous1 ~]# echo $var3
7

            (4) var=$(expr arg1 arg2 arg3 …)

[root@centous1 ~]# var4 = $(expr $var2 + $var3)
-bash: var4: command not found
[root@centous1 ~]# var4=$(expr $var2 + $var3)
[root@centous1 ~]# echo $var4
12
这里我犯了一个错误,注意等号的两边是没有空格的。

            (5) declare –i var = 数值

            (6) echo ‘算术表达式’ | bc

乘法符号有些场景中需要转义,如*

bash有内建的随机数生成器:$RANDOM(1-32767) echo $[$RANDOM%50] :0-49之间随机数

自增,自减:

        let var+=1

        let var++

        let var-=1

        let var–

逻辑运算

 根据退出状态而定,命令可以有条件地运行

        • && 代表条件性的AND  THEN

        • ||  代表条件性的OR  ELSE

数值测试:

        -gt: 是否大于;

        -ge: 是否大于等于;

        -eq: 是否等于;

        -ne: 是否不等于;

        -lt: 是否小于;

        -le: 是否小于等于;

 字符串测试:

        ==:是否等于;

        >: ascii码是否大于ascii码

        <: 是否小于

        !=: 是否不等于

        =~: 左侧字符串是否能够被右侧的PATTERN所匹配 注意: 此表达式一般用于[[  ]]中;

        -z "STRING":字符串是否为空,空为真,不空为假

        -n "STRING":字符串是否不空,不空为真,空为假

注意:用于字符串比较时的用到的操作数都应该使用引号

存在性测试 -a FILE:同-e

-e FILE: 文件存在性测试,存在为真,否则为假;

存在性及类别测试

            -b FILE:是否存在且为块设备文件;

            -c FILE:是否存在且为字符设备文件;

            -d FILE:是否存在且为目录文件;

            -f FILE:是否存在且为普通文件;

            -h FILE 或

            -L FILE:存在且为符号链接文件;

            -p FILE:是否存在且为命名管道文件;

            -S FILE:是否存在且为套接字文件;

 文件权限测试:

            -r FILE:是否存在且可读

            -w FILE: 是否存在且可写

            -x FILE: 是否存在且可执行

文件特殊权限测试:

            -g FILE:是否存在且拥有sgid权限;

            -u FILE:是否存在且拥有suid权限;

            -k FILE:是否存在且拥有sticky权限;

第一种方式:

COMMAND1 && COMMAND2 并且 COMMAND1 || COMMAND2 或者 ! COMMAND   非

如:[ -e FILE ] && [ -r FILE ] 

第二种方式: EXPRESSION1 -a EXPRESSION2 并且 EXPRESSION1 -o EXPRESSION2

或者 ! EXPRESSION 必须使用测试命令进行;

# [ -z “$HOSTNAME” -o $HOSTNAME "==\ "localhost.localdomain" ] && hostname www.magedu.com # [ -f /bin/cat -a -x /bin/cat ] && cat /etc/fstab

原创文章,作者:forest,如若转载,请注明出处:http://www.178linux.com/35337

(0)
上一篇 2016-08-15 12:10
下一篇 2016-08-15 12:10

相关推荐

  • N22—第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; [root@localhost ~]# grep -E "^(root|fedora|user1)"  /etc/passwd |cut -d : -f 1,7 root:/bin/bash fedora:/bin/bash user1:/bin/bas…

    Linux干货 2016-09-11
  • 终端的类型

    Linux下的终端是一个连接系统的接口,它有以下几个分类     tty:虚拟终端       tty是Teletype的缩写。Teletype是最早出现的一种终端设备,很象电传打字机(或者说就是),是由Teletype公司生产的。   &nbsp…

    Linux干货 2016-10-20
  • Linux命令1

    7-13 Linux命令   一、进入终端terminal 1..C1trl+Alt 释放鼠标 2.ifconfig 查询ip地址 3.Ping (IP地址) 查看联网状态 4.ls 查看            -l 列出文件 5.tty、who am i  查看当前的登录终端名…

    Linux干货 2017-07-15
  • PHP高效率写法(详解原因)

    1.尽量静态化:    如果一个方法能被静态,那就声明它为静态的,速度可提高1/4,甚至我测试的时候,这个提高了近三倍。   当然了,这个测试方法需要在十万级以上次执行,效果才明显。   其实静态方法和非静态方法的效率主要区别在内存:静态方法在程序开始时生成内存,实例方法在程序运行中生成内存,所以静…

    Linux干货 2015-05-28
  • awk大法

    awk awk概念 一款用于数据流的文本处理工具,它将文件作为记录序列处理。在一般情况下,文件内容的每行都是一个记录。每行内容都会被分割成一系列的域,因此,我们可以认为一行的第一个词为第一个域,第二个词为第二个,以此类推。AWK程序是由一些处理特定模式的语句块构成的。AWK一次可以读取一个输入行。对每个输入行,AWK解释器会判断它是否符合程序中出现的各个模式…

    Linux干货 2016-12-04
  • 马哥教育网络班20期+第六周课程练习

    请详细总结vim编辑器的使用并完成以下练习题 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;     cp /etc/rc.d/rc.sysinit  /tmp   &n…

    Linux干货 2016-10-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-16 15:09

    写的很详细,总结的·很棒哦,作业需要好好完成哦