核心知识点(一)变量的高级用法

核心知识点(一)变量的高级用法

变量的高级用法

变量替换

语法 说明
${变量名#匹配规则} 从变量开头进行规则匹配,将符合最短的数据删除
${变量名##匹配规则} 从变量开头进行规则匹配,将符合最长的数据删除
${变量名%匹配规则} 从变量尾部进行规则匹配,将符合最短的数据删除
${变量名%%匹配规则} 从变量尾部进行规则匹配,将符合最长的数据删除
${变量名/旧字符串/新字符串} 变量内容符合旧字符串,则第一个旧字符串会被新字符串取代
${变量名//旧字符串/新字符串} 变量内容符合旧字符串,则所有的旧字符串会被新字符串取代

演示demo

[wanghui@www ~]$ variable_1="i love shell,Do you love shell?"
[wanghui@www ~]$ echo "${variable_1}"
i love shell,Do you love shell?
[wanghui@www ~]$ var1=${variable_1#*ov}
[wanghui@www ~]$ echo $var1
e shell,Do you love shell?
[wanghui@www ~]$ var2=${variable_1##*ov}    #贪婪模式
[wanghui@www ~]$ echo $var2
e shell?
[wanghui@www ~]$ var3=${variable_1%ov*}
[wanghui@www ~]$ echo $var3
i love shell,Do you l
[wanghui@www ~]$ var4=${variable_1%%ov*}
[wanghui@www ~]$ echo $var4
i l
[root@www ~]# var5="/usr/local/node/bin:/opt/application/go_1_11/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin"
[root@www ~]# var_5=${var5/bin/BIN}
[root@www ~]# echo $var_5
/usr/local/node/BIN:/opt/application/go_1_11/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
[root@www ~]# var_6=${var5//bin/BIN}
[root@www ~]# echo $var_6
/usr/local/node/BIN:/opt/application/go_1_11/BIN:/usr/local/sBIN:/usr/local/BIN:/sBIN:/BIN:/usr/sBIN:/usr/BIN:/root/BIN

变量测试

image.png

字符串处理

计算字符串长度

方法类型 语法 说明
方法一 ${#string}
方法二 expr length "$string" string有空格,则必须加双引号
[wanghui@www shell_script]$ var1="hello world"
[wanghui@www shell_script]$ len1=${#var1}
[wanghui@www shell_script]$ len1_new=`expr length "$var1"`
[wanghui@www shell_script]$ echo $len1
11
[wanghui@www shell_script]$ echo $len1_new
11

获取子串在字符串中的索引位置

语法 方式
- expr index $string $substring
[wanghui@www shell_script]$ var1="quickstart is a app"
[wanghui@www shell_script]$ ind=`expr index "$var1" start`
[wanghui@www shell_script]$ echo $ind
6
[wanghui@www shell_script]$ ind=`expr index "$var1" uniq`
[wanghui@www shell_script]$ echo $ind
1

计算子串的长度

子串要从头开始

语法 方式
- expr match $string substring
[wanghui@www shell_script]$ var1="quickstart is a app"
[wanghui@www shell_script]$ sub_len=`expr match "$var1" quick`
[wanghui@www shell_script]$ echo $sub_len
5
[wanghui@www shell_script]$ sub_len=`expr match "$var1" quick.*`
[wanghui@www shell_script]$ echo $sub_len
19

抽取子串(切片)

image.png
[wanghui@www shell_script]$ echo $var1
kafka hadoop yarn mapreduce
[wanghui@www shell_script]$ substr1=${var1:10}
[wanghui@www shell_script]$ echo $substr1
op yarn mapreduce
[wanghui@www shell_script]$ substr2=${var1:10:5}
[wanghui@www shell_script]$ echo $substr2
op ya
[wanghui@www shell_script]$ substr3=${var1: -5}    #-5前面有空格
[wanghui@www shell_script]$ echo $substr3
educe
[wanghui@www shell_script]$ substr4=${var1:(-5)}    #这种不需要定格写
[wanghui@www shell_script]$ echo $substr4
educe
[wanghui@www shell_script]$ substr5=`expr substr "$var1" 10 5`    #expr从1开始计数,其他的是从0开始计数
[wanghui@www shell_script]$ echo $substr5
oop y

练习

练习一

需求描述
变量string="Bigdata process framework is Hadoop,Hadoop is an open source project",执行脚本后打印出string字符串变量,并给出用户以下选项:
(1)打印string长度
(2)删除字符串中的Hadoop
(3)替换第一个Hadoop为Mapreduce
(4)替换全部Hadoop为Mapreduce
用户输入数字1|2|3|4可以执行对应的功能,输入Q|q则退出交互模式

思路分析:

  1. 划分不同的功能模块,并写函数
function print_tips
function len_of_string
function del_hadoop
function req_hadoop_mapreduce_first
function req_hadoop_mapreduce_all
  1. 实现第一步定义的功能函数
function print_tips
{
    echo "**********************************"
    echo "(1)打印string长度"
    echo "(2)删除字符串中的Hadoop"
    echo "(3)替换第一个Hadoop为Mapreduce"
    echo "(4)替换全部Hadoop为Mapreduce"
    echo "**********************************"
}

function len_of_string
{
    echo "${#string}"
}

function del_hadoop
{
    echo "${string//Hadoop/}"
}

function req_hadoop_mapreduce_first
{
    echo "${string/Hadoop/Mapreduce}"
}

function req_hadoop_mapreduce_all
{
    echo "${string//Hadoop/Mapreduce}"
}
  1. 程序主流程的设置
while true
do
    echo "【string=$string】"
    echo
    print_tips
    read -p "Please input your choice(1|2|3|4|q|Q):" choice

    case $choice in
        1)
            len_of_string
            ;;
        2)
            del_hadoop
            ;;
        3)
            req_hadoop_mapreduce_first
            ;;
        4)
            req_hadoop_mapreduce_all
            ;;
        q|Q)
            exit
            ;;
        *)
            echo "Error,input only in {1|2|3|4|q|Q}"
            ;;
    esac
done

完整代码如下

#!/bin/bash

string="Bigdata process framework is Hadoop,Hadoop is an open source project"

function print_tips
{
    echo "**********************************"
    echo "(1)打印string长度"
    echo "(2)删除字符串中的Hadoop"
    echo "(3)替换第一个Hadoop为Mapreduce"
    echo "(4)替换全部Hadoop为Mapreduce"
    echo "**********************************"
}

function len_of_string
{
    echo "${#string}"
}

function del_hadoop
{
    echo "${string//Hadoop/}"
}

function req_hadoop_mapreduce_first
{
    echo "${string/Hadoop/Mapreduce}"
}

function req_hadoop_mapreduce_all
{
    echo "${string//Hadoop/Mapreduce}"
}

while true
do
    echo "【string=$string】"
    echo
    print_tips
    read -p "Please input your choice(1|2|3|4|q|Q):" choice

    case $choice in
        1)
            len_of_string
            ;;
        2)
            del_hadoop
            ;;
        3)
            req_hadoop_mapreduce_first
            ;;
        4)
            req_hadoop_mapreduce_all
            ;;
        q|Q)
            exit
            ;;
        *)
            echo "Error,input only in {1|2|3|4|q|Q}"
            ;;
    esac
done
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容