总结的7个shell字符串操作方法和实例分享


每一种语言都有他独自的字符串操作方法,shell也一样,下面以以例子的方式,简单介绍常用方法。

1,取得字符串长度

string=abc12342341          //等号二边不要有空格

echo ${#string}             //结果11

expr length $string         //结果11

expr "$string" : ".*"       //结果11 分号二边要有空格,这里的:根match的用法差不多

2,字符串所在位置

expr index $string '123'    //结果4 字符串对应的下标是从0开始的

这个方法让我想起来了js的indexOf,各种语言对字符串的操作方法大方向都差不多,如果有语言基础的话,学习shell会很快的。

3,从字符串开头到子串的最大长度

expr match $string 'abc.*3' //结果9

个人觉得这个函数的用处不大,为什么要从开头开始呢。

4,字符串截取

echo ${string:4}      //2342341  从第4位开始截取后面所有字符串

echo ${string:3:3}    //123      从第3位开始截取后面3位

echo ${string:3:6}    //123423   从第3位开始截取后面6位

echo ${string: -4}    //2341  :右边有空格   截取后4位

echo ${string:(-4)}   //2341  同上

expr substr $string 3 3   //123  从第3位开始截取后面3位

上面的方法让我想起了,php的substr函数,后面截取的规则是一样的。

5,匹配显示内容

//例3中也有match和这里的match不同,上面显示的是匹配字符的长度,而下面的是匹配的内容

expr match $string '([a-c]*[0-9]*)'  //abc12342341

expr $string : '([a-c]*[0-9])'       //abc1

expr $string : '.*([0-9][0-9][0-9])' //341 显示括号中匹配的内容

这里括号的用法,是不是根其他的括号用法有相似之处呢,

6,截取不匹配的内容

echo ${string#a*3}     //42341  从$string左边开始,去掉最短匹配子串

echo ${string#c*3}     //abc12342341  这样什么也没有匹配到

echo ${string#*c1*3}   //42341  从$string左边开始,去掉最短匹配子串

echo ${string##a*3}    //41     从$string左边开始,去掉最长匹配子串

echo ${string%3*1}     //abc12342  从$string右边开始,去掉最短匹配子串

echo ${string%%3*1}    //abc12     从$string右边开始,去掉最长匹配子串

这里要注意,必须从字符串的第一个字符开始,或者从最后一个开始,

7,匹配并且替换

echo ${string/23/bb}   //abc1bb42341  替换一次

echo ${string//23/bb}  //abc1bb4bb41  双斜杠替换所有匹配

echo ${string/#abc/bb} //bb12342341   #以什么开头来匹配,根php中的^有点像

echo ${string/%41/bb}  //abc123423bb  %以什么结尾来匹配,根php中的$有点像

awk中NR和FNR的区别小结和实例演示
一,NR和FNR的不同NR:表示当前记录数FNR:也表示当前记录数,但是FNR的作用域只在一个文件内.如果重新打开文件,FNR会从1开始.二,实例说明1,测试文件aaa

awk命令、awk编程语言详细介绍和实例
一,什么是awkawk是linux下的一个命令,他对其他命令的输出,对文件的处理都十分强大,其实他更像一门编程语言,他可以自定义变量,有条件语句,

shell脚本中使用iconv实现批量文件转码的代码分享
在开发中,我们经常需要对N多文件编码进行更改,iconv只能对单文件的进行更改,怎么办呢?我们写一个shell脚本来解决这个问题。例子一:使用shell脚