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

相关推荐

  • iptables实验3 关于内网外网的地址转换及端口转换

    地址属于内核,而不属于网卡!!!!     网络防火墙的实现(主要是forward链) 172.16.100.68(A)和172.16.100.67(B) 192.168.12.10(B)和192.168.12.77(C)(VNET2) B作为C的网关   配置B主机的网卡一个为192.168.1.72,另一个为172.16.2…

    Linux干货 2016-10-30
  • test1

    test 

    Linux干货 2016-09-15
  • corosync的高可用——高可用mariadb数据库

    corosync, pacemaker,nfs高可用mariadb 实验环境: 4台CentOS 7 的主机,并关闭的iptalbes和selinux功能 主机1:10.1.43.101 node1 corosync+pacemaker+amp 主机2:10.1.43.102 node2 corosync+pacemaker+amp 主机3:10.1.43.…

    Linux干货 2016-11-24
  • N25-第六周博客作业

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

    Linux干货 2017-02-16
  • vsftpd 配置文件的一些设置

    ftp:File Transfer protocol 文件传输协议 两个连接: tcp:命令连接 tcp:数据连接 主动模式:服务器端通过20端口主动连接客户端,客户端监听在于服务器端的建立连接的端口+1上,服务器工作在tcp/20 被动模式:客户端使用自己与服务器端建立端口+1上连接客户端的随机端口 防火墙上连接追踪 数据要流失化文本:文件流二进制 c/s…

    Linux干货 2017-09-10
  • 计算机硬件及Linux简介

    计算机的组成 计算机主要分成五大部分:输入单元、控制单元、运算单元、存储器、输出单元。 其中,中央处理器(CPU)是一个具有特定功能的芯片,含有微指令集。包括控制单元与运算单元。 控制单元对程序进行控制,调度程序、数据、地址。运算单元负责对数据的各种逻辑运算和数字运算。 计算机的功能 包括但不限于 驱动程序:字面意思。 进程管理:计算机内部能够通过分配资源,…

    Linux干货 2016-10-30

评论列表(1条)

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

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