首页 > 代码库 > #8 bash变量中的字符串处理
#8 bash变量中的字符串处理
一个完整的程序,一般包括4类文件:
二进制文件(可执行文件)、头和库文件、帮助文件、配置文件;
bash——CLI(命令行接口)的一种
bash同样属于完整的应用程序,也有这四类文件:
bash的配置文件:
三类:
profile类:
为交互式登录的shell进程实现功能初始化的配置文件;
bashrc类:
为非交互式登录的shell进程实现功能启动配置的配置文件;
logout类:
为交互式登录的shell进程提供终止及清理类功能的配置文件;
shell的类型:
交互式登录的shell:
1.直接通过某个终端输入账号和密码后登录打开的shell进程;
2.使用su - USERNAME或su -l USERNAME执行切换登录打开的shell进程;
非交互式登录的shell:
1.在图形界面下,通过菜单或右键菜单打开的终端的shell进程;
2.使用su USERNAME执行切换登录打开的shell进程;
bash的配置文件:
profile类:
全局:对所有用户都生效的配置文件;
/etc/profile
/etc/profile.d/*.sh
注意:在RHEL或CentOS系列的操作系统中,通常情况下,如果一个配置文件内容很多,格式复杂,我们会将其切割成多个片段,将切割出来的片段统一的存放在"程序名称.d"目录中;在这样目录中所保存的片段文件,大多以统一的文件后缀名来命名;
用户个人:仅仅只是针对某个用户有效的配置文件;
~/.bash_profile
profile类配置的文件的作用:
1.用于定义用户的环境变量;
2.用于运行脚本或执行命令;
bashrc类:
全局:
/etc/bashrc
用户个人:
~/.bashrc
bashrc类配置的文件的作用:
1.用于定义本地变量;
2.用于定义命令的别名;
3.定义umask;
注意:只有超级用户root可以修改全局类的配置文件;普通用户只能修改其家目录中的个人配置文件;
交互式登录的shell进程,会按照顺序加载下列配置文件:
/etc/profile --> /etc/profile.d/*.sh --> ~/.bash_profile --> ~/.bashrc --> /etc/bashrc
非交互式登录的shell进程,会按照顺序加载下列配置文件:
~/.bashrc --> /etc/bashrc --> /etc/profile.d/*.sh
所有在命令行中执行的命令的操作,只要没涉及到文件的修改的,一般都只是针对当前的shell生命周期有效;只要shell进程结束,所有的设置均失效;
配置文件的作用:使得我们赖以生存的配置信息可以长期有效,只要不修改配置文件中的内容, 每一次打开shell都会使曾经的配置生效;
让配置文件中新定义的配置能够立即生效的方式:
1.source命令:
source /PATH/TO/SOME_CONF_FILES
. /PATH/TO/SOME_CONF_FILES
2.exec命令:
exec /PATH/TO/SOME_CONF_FILES
bash中变量中存放的字符串处理方式:
弱变量:
1.无需事先定义即可使用;
2.没有变量数据类型的硬性要求,默认是字符型;
1.字符串切片:
${#VAR}:返回字符串类型的变量VAR的长度;
${VAR:offset}:返回字符串变量VAR中第offset个字符后面的内容,不包括第offset个字符;offset的取值范围为:0 ~ $[${#VAR}-1]
${VAR:offset:number}:返回字符串变量VAR中从第offset个字符后开始,长度为number的字符部分;
${VAR: -length}:取字符串最右侧的length个字符;
2.基于模式取字串:
${VAR#*PATTERN}:自左而右,查找VAR变量所存储的字符串中,第一次被PATTERN匹配的字符,删除从字符串开始到PATTERN匹配的字符之间的所有字符;
${VAR##*PATTERN}:自左而右,查找VAR变量所存储的字符串中,所有被PATTERN匹配的字符,删除从字符串开始到最好一个PATTERN匹配的字符之间的所有字符;
${VAR%PATTERN*}:自右而左,查找VAR变量所存储的字符串中,第一次被PATTERN匹配的字符,删除从字符串结尾到PATTERN匹配的字符之间的所有字符;
${VAR%%PATTERN*}:自右而左,查找VAR变量所存储的字符串中,所有被PATTERN匹配的字符,删除从字符串结尾到最好一个PATTERN匹配的字符之间的所有字符;
3.查找替换:
${VAR/PATTERN/SUBSTRING}:在VAR变量中查找匹配PATTERN的内容,将其第一个匹配到的结果更换成SUBSTRING;
${VAR//PATTERN/SUBSTRING}:在VAR变量中查找匹配PATTERN的内容,将其所有匹配到的结果都更换成SUBSTRING;
${VAR/#PATTERN/SUBSTRING}:在VAR变量中查找行首匹配PATTERN的内容,将匹配的结果更换成SUBSTRING;
${VAR/%PATTERN/SUBSTRING}:在VAR变量中查找行尾匹配PATTERN的内容,将匹配的结果更换成SUBSTRING;
4.查找删除:
${VAR/PATTERN}:在VAR变量中查找匹配PATTERN的内容,将其第一个匹配到的结果删除;
${VAR//PATTERN}:在VAR变量中查找匹配PATTERN的内容,将其第一个匹配到的结果删除;
${VAR/#PATTERN}:在VAR变量中查找匹配PATTERN的内容,将其行首匹配到的结果删除;
${VAR/%PATTERN}:在VAR变量中查找匹配PATTERN的内容,将其行尾匹配到的结果删除;
5.字符的大小写转换:
${VAR^^}:将VAR变量中的所有小写字母转换为大写字母;
${VAR,,}:将VAR变量中的所有大写字母转换为小写字母;
6.变量赋值:
${VAR:-value}:如果变量VAR为空或未被设置,那么直接返回value的值;否则返回变量VAR的值;
${VAR:+value}:如果变量VAR不为空,则返回value;
${VAR:=value}:如果变量VAR为空或未被设置,那么直接返回value的值,并且将value的值赋值给变量VAR;否则返回变量VAR的值;
7.变量的间接引用:
如果第一个变量的值恰好是第二个变量的变量名,从第一个变量引用第二个变量的值的方法,就称为变量的间接引用,也称为间接变量引用;
VAR1=VAR2
VAR2=value
bash提供了两种格式的间接变量引用方式:
eval MYVAR=\$$VAR1
MYVAR=$(!VAR1)
1.有大文本文件file1,查询file1里面空行的所在行号;
2.编写shell脚本查询file1以abc结尾的行,并打印出前3行。
#8 bash变量中的字符串处理