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

相关推荐

  • N28-第四周

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。
    2、编辑/etc/group文件,添加组hadoop。
    3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。
    4、复制/etc/skel目录为/home/hadoop,要求修改hadoop目录的属组和其它用户没有任何访问权限。
    5、修改/home/hadoop目录及其内部所有文件的属主为hadoop,属组为hadoop。
    6、显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式;
    7、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
    8、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
    9、找出/etc/passwd文件中的一位数或两位数;
    10、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
    11、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
    12、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
    13、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

    2017-12-30
  • GRUB管理

    对于运维人员来说,想要熟练掌握linux,那么久要对linux的启动流程有一个详细的了解,而今天我们就一起来学习一下linux启动中最重要的一个阶段——GRUB引导阶段。 Linux启动流程 grup: GRand Unified Bootloader  由上图可知,grub属于系统启动过程中一个必须的阶段。而这个阶段又分为了三个小的阶段,分别是s…

    2017-09-02
  • 逻辑卷的创建与移除

    一、弹性控制磁盘大小的lvm:     假如有这样一个场景,在初始安装linux系统时给 /home分区设置了一定大小,但是过了一段时间后,你发现初始分配的大小远不能满足公司的扩大,员工增加,需要分配的账号的磁盘空间也变大,这时你应该怎么办?是挂载一块更大的硬盘,将原来的小硬盘拆除掉吗?其实在linux中有lvm可动态增大文件系…

    Linux干货 2016-08-30
  • 编辑器之神VS神之编辑器

      在linux下有两款非常棒的处理器,它们的功能异常的强大,在普通使用者手中,我们或许仅仅把它们当做文本处理器,但在官方文档中,它们不仅仅被定义为开发工具。正如在windows下,office在我们手中仅仅是文本,表格,PPT等文件的处理工具,而在大神手中,Excel是可以用来作画的!PowerPoint 还可以用来播放视频!  &nb…

    Linux干货 2017-08-05
  • LNMP内网部署wiki

    需求:内部人员经常到查阅资料,考虑在内网搭建wiki站点。 实验拓扑: 实验环境:        Nginx,PHP:192.168.198.160,10.0.0.07        MySQL:10.0.0.8 软件包:  &n…

    Linux干货 2015-10-15
  • 磁盘阵列(raid),划分逻辑卷(lvm)

    磁盘阵列(raid),划分逻辑卷(lvm)       将来我们在生产环境中由于磁盘的来回读写量比较大,所以就容易导致磁盘的损坏率比较高。但是,处于生产环境的需求,我们还得保证服务器的正常运行。或者说我们需要对服务器的读写速率进行优化,这样我们就不得不运用到这个磁盘阵列(raid )。而所谓的磁盘阵列就是使用…

    Linux干货 2016-08-29

评论列表(1条)

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

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