#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行。

时间: 2024-12-19 09:41:42

#8 bash变量中的字符串处理的相关文章

其他文本处理命令以及bash变量中的一些字符串的处理方法

其他的文本处理命令: 1.wc 2.cut命令: cut - 在文件的每一行中提取片断 注意:能够被cut修剪的文件或数据内容,一般是具有某种特定格式或结构的文本文件或数据内容: 如 :/etc/passwd 格式:cut [OPTION]... [FILE]... 常用选项: -d, --delimiter=DELIM:指定在实施修剪操作时所使用的字段分隔符号,默认是TAB(空白字符): -f, --fields=LIST:根据指定的字段分隔符号来指定要保留的字段编号列表: LIST可以称为字

bash变量中字符串的操作

1.字符串的切片 ${#VAR}:返回字符类型变量的变量值的长度 ${VAR:offset}:返回字符型变量中第"offset"位置之后的内容,不包括第offset位,offset取值范围为:0-$[$[#VAR]-1] ${VAR:offset:number}:返回字符型变量中第"offset"个字符后开始长度为number的字符部分 ${VAR: -lenth}:取字符型变量字符串最右侧的"length"个字符(注意空格) 示例: 2.基于模

Shell基础-Bash变量-用户自定义变量

变量设置规则: 变量名称可以由字母.下划线和数字组成,但是不能由数字开头. 在Bash中变量的默认类型是字符串类型,若需要进行数值运算,则需指定变量类型为数值型.变量用等号链接,且两边不能有空格.若需要有空格,则用单引号或者双引号包括. Bash变量中“\”为转义符. 变量的值可以叠加,不过变量需要用双引号包括“$变量名”或者${变量名}. 如果把命令的结果作为变量值赋予变量,则需要使用反引号``或者$()包含命令

bash的变量中存放的字符串的处理方式

bash变量: 弱变量: 1.无需实现定义即可应用: 2.变量没有数据类型的硬性要求,默认是字符型: 1.字符串切片: ${#VAR}:返回字符型变量的变量值长度: ${VAR:offset}:返回字符型变量中第"offset"位置之后的内容,不包括第"offset"位置的字符: offset取值范围:0-$[${#VAR-1}] ${VAR:offset:number}:返回字符型变量中从第"offset"个字符后开始长度为"numb

Bash 是如何从环境变量中导入函数的

在上文中曾说到: 所谓的环境变量的真实面目其实就是个任意字符串 Bash 在启动时会将 environ 数组中包含 = 号的字符串导入成为自己的变量 Bash 在启动外部命令时会将自己内部标记为环境变量的变量重组成字符串数组赋值给 environ 本文中继续深入讲三点: environ 数组中可能存在 = 左边名字相同的元素,也就是同名的环境变量,Bash 是怎么导入的? Bash 还可以从环境变量中导入函数,甚至同时导入两个同名的变量和函数 Bash 还可以同时导出两个同名的变量和函数 如果有

bash颜色显示方案、bash配置文件及bash变量字符串处理

bash颜色的显示规则: 调用了ASCII编码对于颜色的设置方案: Ctrl键:\033 [:控制字符和颜色代码之间的分隔符: 所有的颜色代码都应该使用m结尾 颜色代码: 0:表示关闭颜色显示属性,恢复为黑白色: 1:加粗显示文本字符: 4:为文本字符添加下划线标识: 5:使文本字符闪烁: 7:将文本字符的背景颜色和前景颜色交换: 8:将文本字符的背景颜色设置为与前景色相同: 30-39:设置文本字符的前景色,38,39为保留暂时未被使用: 30为灰色:31为红色:32为绿色:33是黄色:34为

bash中的字符串处理

bash的变量中存放的字符串的处理方式: bash变量: 弱变量: 1.无需事先定义即可应用: 2.变量没有数据类型的硬性要求,默认是字符型: 1.字符串切片: ${#VAR}:返回字符类型变量的变量值的长度: ${#VAR:offset}:返回字符型变量中第"offset"之后的内容,不包括"offset"这个位置的字符:offset取值范围:0-$[${#VAR}-1] ${VAR:offset:number}:返回字符型变量中从第"offset&qu

字符串变量中转义符的替换方法

1.通常直接写的字符串中有转义符是前面加[@]就能解决: 如:string str = @"请确认数据有误!\r\n中断程序运行."; 这时实际存入str中的内容是"请确认数据有误!\\r\\n中断程序运行." 2.如果字符串变量中的内容中有直接携带了转义符给怎么替换? 如:假设str中已经存有"请确认数据有误!\r\n中断程序运行."的内容. 这时实际存入str中的内容中的\r和\n是已转义后的内容,不是"\r"或"

查找jar包中.class文件关键字(变量名,字符串)

有时查看日志,常常会发现由框架底层打印的错误日志.要修改这个错误的时候,如果不是对框架特别熟悉,就需要按照可能产生这个错误日志的流程一步一步找,一时半会不一定能找到.比如本人最近对smartfoxserver搭建的服务器做压测的时候,发现最大等待线程数超过20就会打印错误日志,然后就一直在smartfoxserver接受请求的反编译代码里找该错误输出,花了很长时间一直没找到.然后我在想能否用inputstream来查询字符串,试验代码如下: import java.io.BufferedRead