linux基础学习(数组、字符串变量处理)

2016-08-22

授课内容:

数组

高级字符串操作

一、数组

  变量:存储单个元素的内存空间

  数组:存储多个元素的连续的内存空间,相当于多个变量的集合。

  数组名和索引

  索引:编号从0开始,属于数值索引

  bash的数组支持稀疏格式(索引不连续)

    1、声明数组:

        declare -a ARRAY_NAME(并非强制声明,但最好按规范声明)

        declare -A ARRAY_NAME: 关联数组

    2、数组元素的赋值:

    (1) 一次只赋值一个元素;

        ARRAY_NAME[INDEX]=VALUE

[19:41 [email protected]~]# arr=(1 2 3 4 5)
[19:41 [email protected]~]# echo ${arr[@]}
1 2 3 4 5
[19:41 [email protected]~]# arr[5]=88
[19:41 [email protected]~]# echo ${arr[@]}
1 2 3 4 5 88
[19:41 [email protected]~]# arr[10]=188
[19:42 [email protected]~]# echo ${arr[@]}
1 2 3 4 5 88 188

    (2) 一次赋值全部元素:

        ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)

[19:41 [email protected]~]# arr=(1 2 3 4 5)
[19:41 [email protected]~]# echo ${arr[@]}
1 2 3 4 5

    3、引用数组:

        引用数组元素:${ARRAY_NAME[INDEX]},注意:省略[INDEX]表示引用下标为0的元素

[19:43 [email protected]~]# echo ${arr[@]}
1 2 3 4 5 88 188
[19:43 [email protected]~]# echo ${arr[1]}
2

        数组的长度(数组中元素的个数):

            ${#ARRAY_NAME[*]}

            ${#ARRAY_NAME[@]}

[19:44 [email protected]~]#echo ${arr[@]}
1 2 3 4 5 88 188
[19:44 [email protected]~]# echo ${#arr[@]}
7
[19:44 [email protected]~]# echo ${#arr[*]}
7

    4、数组数据处理:切片

        数组切片:${ARRAY[@]:offset:number}

        offset: 要跳过的元素个数

        number: 要取出的元素个数

        取偏移量之后的所有元素${ARRAY[@]:offset}

[19:46 [email protected]~]# echo ${arr[@]}
1 2 3 4 5 88 188
[19:46 [email protected]~]# echo ${arr[@]:2:3}
3 4 5 #跳过两个元素,取后面三个元素

    5、删除数组中的某元素:导致稀疏格式

        unset ARRAY[INDEX]

二、字符串处理

    1、字符串切片:

        ${#var}:返回字符串变量var的长度

        ${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 到${#var}-1 之间

        ${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

        ${var: -lengh}:取字符串的最右侧几个字符:

        注意:冒号后必须有一空白字符

[19:50 [email protected]~]# str="nihaolinux"
[19:51 [email protected]~]# echo $str
nihaolinux
[19:51 [email protected]~]# echo ${#str}
10 #取字符串的长度
[19:51 [email protected]~]# echo ${str:2}
haolinux #从第二个字符串(不包括第二个)开始到最后
[19:51 [email protected]~]# echo ${str:2:3}
hao #从第二个字符串(不包括第二个)开始取后三个字符
[19:51 [email protected]~]# echo ${str: -5}
linux#取最后侧起5个字符

    2、基于模式取子串:

        (1)${var#*word}:其中word可以是指定的任意字符

            功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次出现word字符之间的所有字符

        (2)${var##*word}

同上,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容

        (3)${var%word*}:其中word可以是指定的任意字符;

功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向左至第一次出现word字符之间的所有字符;

        (4)${var%%word*}

            同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符;

[19:55 [email protected]~]# str=`getent passwd root`
[19:56 [email protected]~]# echo $str
root:x:0:0:,,62985600:/root:/bin/bash
[19:56 [email protected]~]# echo ${str#*root} #删除第一次出现root(包含)字符串及之前的字符
:x:0:0:,,62985600:/root:/bin/bash
[19:56 [email protected]~]# echo ${str##*root} #删除最后出现root(包含)字符串及之前的字符
:/bin/bash
[19:56 [email protected]~]# echo ${str%root*} #删除从右到左第一次出现root(包含)字符串及之前的字符
root:x:0:0:,,62985600:/
[19:56 [email protected]~]# echo ${str%%root*} #删除从右到左最后出现root(包含)字符串及之前的字符

    3、查找替换

        (1)${var/pattern/substi}:

            查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替换之

        (2)${var//pattern/substi}: 

            查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替换之

        (3)${var/#pattern/substi}:

            查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替换之

        (4)${var/%pattern/substi}:

            查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替换之

[19:57 [email protected]~]# echo ${str/root/ROOT}
ROOT:x:0:0:,,62985600:/root:/bin/bash
[20:01 [email protected]~]# echo ${str//root/ROOT}
ROOT:x:0:0:,,62985600:/ROOT:/bin/bash
[20:02 [email protected]~]# echo ${str/#root/ROOT}
ROOT:x:0:0:,,62985600:/root:/bin/bash
[20:02 [email protected]~]# echo ${str/%bash/BASH}
root:x:0:0:,,62985600:/root:/bin/BASH

    4、查找并删除

        ${var/pattern}:查找var所表示的字符串中,删除第一次被pattern所匹配到的字符串

        ${var//pattern}:所有

        ${var/#pattern}:首行

        ${var/%pattern}:行尾

[20:02 [email protected]~]# echo ${str/root}
:x:0:0:,,62985600:/root:/bin/bash
[20:05 [email protected]~]# echo ${str//root}
:x:0:0:,,62985600:/:/bin/bash
[20:05 [email protected]~]# echo ${str#root}
:x:0:0:,,62985600:/root:/bin/bash
[20:06 [email protected]~]# echo ${str%bash}
root:x:0:0:,,62985600:/root:/bin/

三、创建临时文件

        mktemp命令:创建的临时文件可避免冲突

        mktemp[OPTION]… [TEMPLATE]

        TEMPLATE: filename.XXX

        【X至少要出现三个】

        OPTION:

        -d: 创建临时目录

        –tmpdir=/DIR:指明临时文件所存放的目录位置

        实例:

        #mktemp–tmpdir=/testdirtest.XXXXXX

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

(0)
麦德良麦德良
上一篇 2016-08-24 10:25
下一篇 2016-08-24 10:25

相关推荐

  • linux程序包管理

    对第五周学习的内容进行总结

    2018-01-01
  • test

    test the URL.

    Linux干货 2016-12-03
  • 马哥教育网络班21期-第二周课程作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 cp即copy的简写,我们可以用它来复制一些文件即将,源文件的数据流复制到目的文件中。和下面要讲的rm,mv,一样都是一些非常基础的命令。关于这个命令,我们有个小窍门,那就是根据 ls file这个命令是否执行成功来判断file文件是否存在。 关于cp,我们有一些要点要注意: cp…

    Linux干货 2016-07-07
  • 【26期】Linux第八周学习小总结

        前言     本周的学习已经过去了,虽然本周学习中老师一直都有说,哎呀,这个不重要,以后有网络管理员给你们来做,了解一下就行,然而话锋一转就又说,其实小公司没有网络管理员,如果你们不好好学,以后就会做得更多更杂的工作,这一周的知识点基本上都是在一个pdf上的,大概有200…

    2017-09-02
  • LB Cluster:lvs

    Linux Cluster: Cluster:计算机集合,为解决某个特定问题组合起来形成的单个系统; Linux Cluster类型: LB:Load Balancing,负载均衡; HA:High Availiablity,高可用; A=MTBF/(MTBF+MTTR) (0,1):90%, 95%, 99%, 99.5%, 99.9%, 99.99%, …

    Linux干货 2017-06-24
  • Linux磁盘管理

     I/O Ports:I/O设备地址   一切皆文件:             poen(),read(),write(),close()   设备类型:     &nb…

    Linux干货 2016-08-29

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-26 09:42

    文章对数组的知识点整理的很详细,并通过示例展示了数组的申明和调用,最后可以通过一个示例来展示数组在脚本中的用法,跟其在脚本中的作用,这样整篇文章会更完整了。