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:13
下一篇 2016-08-24 10:25

相关推荐

  • rpm程序包管理器使用详解

    rpm程序包管理器的使用详解   说到程序包管理器,就会想到基于CentOS系统上的rpm命令与其对应的前端处理器yum。所谓程序包,是将源代码转换为二进制格式,再组织成一个或者多个包文件供用户安装使用。rpm程序包的命名格式如下:   name-VERSION-release.arch.rpm   软件名-版本号(分为主版本m…

    Linux干货 2016-08-21
  • linux文件管理及bash的基本特性

    一、常用的文件和目录管理命令1、pwd命令:用来显示当前的工作目录语法格式:直接输入pwd回车显示当前的工作目录示例:用pwd命令显示当前的工作目录[root@suyiwen ~]# pwd/root2、mkdir命令:用来创建目录文件语法格式:mkdir [OPTION]… DIRECTORY…常用option:-m,用来指定目录的…

    Linux干货 2018-03-11
  • 搭建个人博客&论坛(LAMP):wordpress、discuz、phpMyAdmin

    搭建个人博客&论坛(LAMP):wordpress、discuz、phpMyAdmin 一、快速部署LAMP架构平台 1.CentOS 6系统部署 所需安装包:httpd, php, mysql-server, php-mysql ]# yum install -y  httpd php&n…

    Linux干货 2016-10-17
  • Linux的文本处理工具之sed的使用

    Sed文本处理工具 一、认识sed工具: sed是一种流编辑器,一次处理一行内容。当进行处理时,把当前处理的行存储在临时的缓冲区中(俗称“模式空间”)后,再用sed命令去处理缓冲区的内容,最后把处理过的缓冲区内容送往屏幕打印显示。接着处理下一行,不断重复进行读取、处理、输出,直到文件末尾。  注:sed命令处理文本,文件内容本身并没有改变,除非你使…

    Linux干货 2016-08-10
  • 马哥教育网络班22期+第1周课程练习

    1、描述计算机的组成及其功能。     计算机由五大功能部分组成(冯诺依曼体系):运算器、控制器、储存器、输入设备、输出设备,对应到具体的硬件设备如下:     CPU    :    包含运算器、控…

    Linux干货 2016-08-15
  • 第九周:shell脚本之判断练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i LoginUser=0 declare -i NologinUser=0 while r…

    Linux干货 2016-11-21

评论列表(1条)

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

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