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

2016-08-22

授课内容:

数组

高级字符串操作

一、数组

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

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

  数组名和索引

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

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

    1、声明数组:

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

        declare -A ARRAY_NAME: 关联数组

    2、数组元素的赋值:

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

        ARRAY_NAME[INDEX]=VALUE

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

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

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

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

    3、引用数组:

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

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

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

            ${#ARRAY_NAME[*]}

            ${#ARRAY_NAME[@]}

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

    4、数组数据处理:切片

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

        offset: 要跳过的元素个数

        number: 要取出的元素个数

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

[19:46 root@Centos7.2~]# echo ${arr[@]}
1 2 3 4 5 88 188
[19:46 root@Centos7.2~]# 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 root@Centos7.2~]# str="nihaolinux"
[19:51 root@Centos7.2~]# echo $str
nihaolinux
[19:51 root@Centos7.2~]# echo ${#str}
10 #取字符串的长度
[19:51 root@Centos7.2~]# echo ${str:2}
haolinux #从第二个字符串(不包括第二个)开始到最后
[19:51 root@Centos7.2~]# echo ${str:2:3}
hao #从第二个字符串(不包括第二个)开始取后三个字符
[19:51 root@Centos7.2~]# 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 root@Centos7.2~]# str=`getent passwd root`
[19:56 root@Centos7.2~]# echo $str
root:x:0:0:,,62985600:/root:/bin/bash
[19:56 root@Centos7.2~]# echo ${str#*root} #删除第一次出现root(包含)字符串及之前的字符
:x:0:0:,,62985600:/root:/bin/bash
[19:56 root@Centos7.2~]# echo ${str##*root} #删除最后出现root(包含)字符串及之前的字符
:/bin/bash
[19:56 root@Centos7.2~]# echo ${str%root*} #删除从右到左第一次出现root(包含)字符串及之前的字符
root:x:0:0:,,62985600:/
[19:56 root@Centos7.2~]# 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 root@Centos7.2~]# echo ${str/root/ROOT}
ROOT:x:0:0:,,62985600:/root:/bin/bash
[20:01 root@Centos7.2~]# echo ${str//root/ROOT}
ROOT:x:0:0:,,62985600:/ROOT:/bin/bash
[20:02 root@Centos7.2~]# echo ${str/#root/ROOT}
ROOT:x:0:0:,,62985600:/root:/bin/bash
[20:02 root@Centos7.2~]# 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 root@Centos7.2~]# echo ${str/root}
:x:0:0:,,62985600:/root:/bin/bash
[20:05 root@Centos7.2~]# echo ${str//root}
:x:0:0:,,62985600:/:/bin/bash
[20:05 root@Centos7.2~]# echo ${str#root}
:x:0:0:,,62985600:/root:/bin/bash
[20:06 root@Centos7.2~]# 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

相关推荐

  • 系统自动化安装、selinux

    系统自动化安装 系统启动流程:bootloader–>kernel(initramfs)–>rootfs–>anaconda–>/sbin/init anaconda: 系统安装程序    tui: 基于图形库curses的文本配置窗口 &nbsp…

    Linux干货 2016-09-22
  • 开发团队的效率

    我之前写过一篇叫《加班与效率》的文章,从概念上说了一些我对“效率”的认识,但是那篇文章趋于概念化,对于一些没有经历过这样的环境的同学来说,可能会觉得太抽象了。很早以前就想写一篇更具体一点的,可执行的文章与《加班与效率》这篇文章相辉映,并再把我两年前在杭州QCon上的那个“鼓吹工程师文化”的《建一支强大的小团队》(新浪微盘)的观点再加强一下。 但是我遇到了一些…

    Linux干货 2016-08-15
  • Linux的简介

    Linux的简介 冯诺依曼体系结构 主要特点:使用存储器,采用二进制(据说,采用二进制的灵感来源于中国的八卦,2变4,4变8…) 体系介绍:其由几大部分组成,输入设备,运算器,控制器,内部存储器,外部存储器,输出设备。 目前,输入设备就是指键盘鼠标, 运算器和控制器现在统称CPU。其实已经内置了两个功能。 内部存储器就是内存,某种意义上,缓存也算…

    Linux干货 2016-10-28
  • 分析命令中含有e2fs

    分析命令中含有e2fs 目  录 1、mke2fs  2、tune2fs 3、dump2fs 4、e2fsck 这周学到了几条命令,超级纳闷为什么这些命令都带有e2fs ,看不懂。毕竟在我的认知中linux的命名大部分都是见名知义,例如history(查看历史命令),fdisk (分区),反观这些命令很长而且还是奇怪的…

    Linux干货 2017-08-20
  • find 的使用及练习

    find是个使用频率比较高的命令。常常用它在系统特定目录下,查找具有某种特征【名字类型属主权限等】的文件。find命令的格式: find  [-path ..] -options [-print -exec -ok] path:要查找的目录路径。 ~ 表示$HOME目录 . 表示当前目录 / 表示根目录 -print :表示将结果输出到标准输出-e…

    Linux干货 2017-06-11
  • 系统启动和内核管理以及几个重要实验

    Centos启动流程:     1.加载BIOS的硬件信息,获取第一个启动设备     2.读取第一个启动设备MBR的引导加载程序(grub)的启动信息     3.加载核心操作系统的核心信息,核心开始解压缩,并尝试驱动所有的硬件设备 &n…

    Linux干货 2017-05-15

评论列表(1条)

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

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