Linux Shell编程之五字符串的处理

简介:

shell编程之字符串处理


    在 shell 中,由于是一种弱类型的语言,在没有事先申明变量类型的情况下,所有的变量都是字符串。所以对字符串的处理就显得相当重要了。

    下面介绍常见的对字符串处理的操作。


一、字符串切片

${string_var:offest:length},类似于数组元素的提取。

1
2
3
4
# 这里的string_var是一个变量,offest 是字符串的开始偏移量,length是切去字符串的长度
var=dhcpd:x:177:177:DHCP server:/: /sbin/nologin
[root@server ~] # echo ${var:6:3}
x:1

${string_var:offest}

1
2
3
# 不指定 length 指,默认显示到最后
[root@server ~] # echo ${var:6}
x:177:177:DHCP server:/: /sbin/nologin

${string_var: -offest}

1
2
3
# 获取尾部起向前指定长度的字符
[root@server ~] # echo ${var: -7}
nologin


二、获取子串

1、${string_var#*word}

1
2
3
4
# 在string_var变量中存储的子串中,自左向右,查找第一次出现word,删除字符开始至此word处的所有内容
var= /etc/sysconfig/network-scripts/sysconfig/etc/cmd
[root@server ~] # echo ${var#*etc}
/sysconfig/network-scripts/sysconfig/etc/cmd

2、${string_var##*word}

1
2
3
4
5
6
# 在string_var变量中存储的子串中,自左向右,查找第一次出现word,删除字符开始至此word处的所有内容
[root@server ~] # echo ${var##*etc}
/cmd
## 通常情况下同这种方法可以取得一个目录的基名
[root@server ~] # echo ${var##*/}
cmd

3、${variable%word*}

1
2
3
4
# 在variable中存储字串上,自右而左,查找第一次出现word,删除此word处至字串尾部的所有内容
var= /etc/sysconfig/network-scripts/sysconfig/etc/cmd
[root@server ~] # echo ${var%etc*}
/etc/sysconfig/network-scripts/sysconfig/

4、${variable%%world*}

1
2
3
# 在variable中存储字串上,自右而左,查找最后一次出现word,删除此word处至字串尾部的所有内容;
[root@server ~] # echo ${var%%etc*}
/


三、查找替换

1、${string_var/pattern/new_string}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# 在string_var字符串变量中,自左向右,替换第一次被pattern匹配到的子串为new_string
var= bash :x:4403:4403:: /home/bash : /bin/bash
 
[root@server ~] # echo ${var/bash/zsh/}
zsh/:x:4403:4403:: /home/bash : /bin/bash
 
# 在这里可以使用文件通配符,像 ? * 等
[root@server ~] # echo ${var/b??h/zsh/}
zsh/:x:4403:4403:: /home/bash : /bin/bash
 
# 使用 # 可以锚定变量值首部
[root@server ~] # echo ${var/%b??h/zsh/}
bash :x:4403:4403:: /home/bash : /bin/zsh/
 
# 使用 % 可以锚定变量值尾部
[root@server ~] # echo ${var/#b??h/zsh/}
zsh/:x:4403:4403:: /home/bash : /bin/bash


2、${string_var//pattern/new_string}

1
2
3
# 在string_var字符串变量中,自左向右,替换被pattern匹配到的子串为new_string,匹配到几次就替换几次
[root@server ~] # echo ${var//b??h/zsh/}
zsh/:x:4403:4403:: /home/zsh/ : /bin/zsh/


四、查找删除

1
2
# 所用的变量如下
var= bash :x:4403:4403:: /home/bash : /bin/bash

1、${string_var/pattern}

1
2
3
4
5
6
7
# 在string_var字符串变量中,自左向右,替换第一次被pattern匹配到的子串后将其删除
[root@server ~] # echo ${var/b??h/}
:x:4403:4403:: /home/bash : /bin/bash
 
# 同样可以使用 # 和 % 锚定变量值首部和尾部
[root@server ~] # echo ${var/%b??h/}
bash :x:4403:4403:: /home/bash : /bin/

2、${string_var//pattern}

1
2
3
# 在string_var字符串变量中,自左向右,替换被pattern匹配到的子串为new_string,匹配到几次就删除几次
[root@server ~] # echo ${var//b??h/}
:x:4403:4403:: /home/ : /bin/


五、大小写转换

1、${string_var^^}

1
2
3
4
5
6
7
8
9
var=var= bash :x:4403:4403:: /home/bash : /bin/bash
 
# 将string_var变量中的小写字母全部转换为大写字母
[root@server ~] # echo ${var^^}
BASH:X:4403:4403:: /HOME/BASH : /BIN/BASH
 
# 也可以指定那个字符替换大写,只支持单个字符
[root@server ~] # echo ${var^^a}
bAsh:x:4403:4403:: /home/bAsh : /bin/bAsh

2、${string_var,,}

1
2
3
4
5
6
7
8
var1=BASH:X:4403:4403:: /HOME/BASH : /BIN/BASH
 
# 将string_var变量中的大写字母全部转换为小写字母
[root@server ~] # echo ${var1,,}
bash :x:4403:4403:: /home/bash : /bin/bash
 
[root@server ~] # echo ${var1,,A}
BaSH:X:4403:4403:: /HOME/BaSH : /BIN/BaSH


六、变量复制操作

1、${string_var:-value}

1
2
3
4
5
6
7
8
9
10
11
# 如果 string_var 变量没有被set或者变量值为空的话,就将 string_var 变量值设置为 value。
# 但是这个不会改变原来变量的值
[root@server ~] # name=centos
[root@server ~] # echo ${name:-redhat}
centos
[root@server ~] # unset name
[root@server ~] # echo ${name:-redhat}
redhat
[root@server ~] # name=
[root@server ~] # echo ${name:-redhat}
redhat

${string_var-value}

1
2
3
4
5
6
7
8
9
10
# 如果 string_var 变量没有被set话,就将 string_var 变量值设置为 value。
[root@server ~] # name=
[root@server ~] # echo ${name-redhat}
 
[root@server ~] # unset name
[root@server ~] # echo ${name-redhat}
redhat
 
# ${string_var:-value} 与 ${string_var-value}的区别如下:
# 在变量值为空的时候,${string_var-value} 不会被设定为value的值,还是原来的空值


2、${string_var:=value}  ${string_var=value}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# ${string_var:=value} 与 ${string_var=value} 如果原来的没有被 set 或者为空
# 就会将 value的值赋值给 string_var变量
 
# ${string_var:=value} 与 ${string_var=value} 区别如下:
[root@server ~] # name=
[root@server ~] # echo ${name=redhat}
 
[root@server ~] # echo $name
 
[root@server ~] # name=
[root@server ~] # echo ${name:=redhat}
redhat
[root@server ~] # echo $name
redhat
 
# 当原来的变量值为空的话,二者有区别,其他一样,区别如下:
# 如果原来的变量值为空的话:
# ${name=redhat} 处理时,保持原来变量的空值
# ${name:=redhat} 处理时,会将变量值设置为 redhat
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# ${string_var:=value} 和 ${string_var:-value} 表示意义相同,区别如下:
 
[root@server ~] # unset name
[root@server ~] # echo ${name:-redhat}
redhat
[root@server ~] # echo $name
 
[root@server ~] # echo ${name:=redhat}
redhat
[root@server ~] # echo $name
redhat
 
# ${string_var:-value} 不会改变原来变量的值
# ${string_var:=value} 在执行赋值操作后会改变原来变量的值


3、${string_var:+value}

1
2
3
4
5
# 如果 string_var 变量被set或者变量值不为空的话,就将 string_var 变量值设置为 value。
 
[root@server ~] # name=centos
[root@server ~] # echo ${name:+redhat}
redhat

${string_var+value}

1
2
3
4
5
# 如果 string_var 变量被set的话,就将 string_var 变量值设置为 value。
 
[root@server ~] # name=
[root@server ~] # echo ${name+redhat}
redhat


4、${string_var:?err_msg}  ${string_var?err_msg}

1
2
3
4
# ${string_var?err_msg}, ${string_var:?err_msg}如果 string_var 被 set,那就是用 set 的值,否则 print err_msg.
 
# 这两种办法绝大多数时候用法都一样,只有在 $string_var 被声明并设置为空的时候,会有区别
#
1
2
3
4
5
6
[root@server ~] # debug=
[root@server ~] # echo ${debug:?err_type1}
- bash : debug: err_type1
[root@server ~] # debug=error1
[root@server ~] # echo ${debug:?err_type1}
error1


七、补充

1、${#var_name}  

1
2
3
4
# 取得var_name变量的长度
[root@server ~] # name="boy"
[root@server ~] # echo ${#name}
3

    总结:本文主要介绍了对字符串的相关处理。包括求长度,查找替换,查找删除,大小写转换,赋值等的相关操作。当然,这些操作也可以用像grep,sed,awk的文本处理工具完成,但是这些操作是shell内置的功能,执行速度等方面要好于文本处理工具。










本文转自 羊木狼 51CTO博客,原文链接:http://blog.51cto.com/guoting/1534127,如需转载请自行联系原作者
目录
相关文章
|
3月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
465 9
|
3月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
3月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
392 2
|
5月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
701 1
|
7月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
233 4
|
7月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
462 3
|
Unix Shell Linux
|
Shell Linux 程序员
在Linux中, 什么是shell函数?如何使用它们?
在Linux中, 什么是shell函数?如何使用它们?