Shell字符串处理

shell字符串的处理
1、计算字符串的长度
方法一:${#string}
方法二:expr length "$string"    string有空格,则必须加双引号
例子:
    var1="Hello World"
    len=${#var1}
    len=`expr length "$var1"`
2、获取字符索引位置
expr index $string $substring
例子:
    var1="quickstart is a app"
    ind=`expr index "$var1" start`
    [root@k8smaster shell]# ind=`expr index "$var1" uniq`
    [root@k8smaster shell]# echo $ind
    1
说明:返回最先找到的字符索引位置
3、计算子串长度
expr match $string substr
例子:
    var1="quickstart is a app"
    sub_len=`expr match "$var1" app`
    [root@k8smaster shell]# var1="quickstart is a app"
    [root@k8smaster shell]# sub_len=`expr match "$var1" app`
    [root@k8smaster shell]# echo $sub_len
    0
说明:必须从头匹配否则匹配不到。
4、抽取子串
方法一:${string:position}            #从string中的position开始
方法二:${string:position:length}    #从position开始,匹配长度为length
方法三:${string: -position}        #从右边开始匹配
方法四:${string:(position)}        #从左边开始匹配
方法五:expr substr $string $position $length 从position开始,匹配长度为length
例子:
    var1="kafka hadoop yarn mapreduce"
    substr1=${var1:10}        
    substr2=${var1:10:5}
    substr3=${var1: -5}
    substr4=${var1:(-5)}
    substr5=${var1: -5:2}
    substr6=`expr substr "$var1" 10 5`
    注意:使用expr索引下标从1开始,使用${string:position}索引计数从0开始

需求描述:
变量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 rep_hadoop_mapreduce_first
    function rep_hadoop_mapreduce_all
2、实现第一步所定义的函数功能

3、程序主程序的设计
#!/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 rep_hadoop_mapreduce_first
{
  echo "${string/Hadoop/Mapreduce}"
}
function rep_hadoop_mapreduce_all
{
  echo "${string//Hadoop/Mapreduce}"
}
while true
do
  echo "【string=$string】"
  echo
  print_tips
  read -p "Pls input your choice(1|2|3|4|q|Q):" choice
  case $choice in
        1)
                len_of_string
                ;;
        2)
                del_hadoop
                ;;
        3)
                rep_hadoop_mapreduce_first
                ;;
        4)
                rep_hadoop_mapreduce_all
                ;;
        q|Q)
                exit
                ;;
        *)
                echo "Error,input only in {1|2|3|4|q|Q}"
                ;; 
  esac
done

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值