bash的颜色规则以及配置文件

bash的颜色显示规则:
 ascii编码对于颜色进行设置;

\033:Ctrl键
 [:控制字符和颜色代码之间的间隔字符
 0m:关闭颜色属性命令;
 1m:加粗显示文本字符;
 4m:为文本字符加下划线标识;
 5m:使文本字符闪烁;
 7m:将文本字符的背景色和前景色交换显示;
 8m:将文本字符的背景色和前景色设置为相同颜色;

30m-39m:设置文本字符的前景色;38m和39m暂时保留;
 40m-49m:设置文本字符的背景色;48m和49m暂时保留;

例子:echo -e "\033[5;1;31;47mhello world\033[0m"

一个完整的程序,一般包括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)

时间: 2024-10-13 06:47:19

bash的颜色规则以及配置文件的相关文章

#8 bash的颜色显示规则

bash的颜色显示规则: ascii编码对于颜色进行设置: \033:Ctrl键 [:控制字符和颜色代码之间的间隔字符 0m:关闭颜色属性命令: 1m:加粗显示文本字符: 4m:为文本字符加下划线标识: 5m:使文本字符闪烁: 7m:将文本字符的背景色和前景色交换显示: 8m:将文本字符的背景色和前景色设置为相同颜色: 30m-39m:设置文本字符的前景色:38m和39m暂时保留: 40m-49m:设置文本字符的背景色:48m和49m暂时保留: 例子:echo -e "\033[5;1;31;4

Bash常用的几个配置文件

Login shells读下面的启动文件: 文件 内容 /etc/profile 对所有用户开放的全局配置文件 ~/.bash_profile 某个用户个人的启动文件,能用作个人的全局设置 ~/.bash_login 如果 ~/.bash_profile找不到,则bash尝试读取这个脚本 ~/.profile 如果这两个文件~/.bash_profile, ~/.bash_login 都找不到,bash就读取这个文件,这是个默认文件 NOTE: export PATH=$PATH:directo

Linux下通过设置PS1变量改变bash提示符颜色

我们都知道bash中,可以通过PS1变量改变提示符的颜色.当命令输出较长时,往往不容易第一眼看到输出是从哪里开始的,通过改变改变PS1变量,可以更改bash提示符的颜色,这样在人群中多看了一眼,就能够找到输出开始的地方了.另外,设置颜色也可以让命令行更漂亮 我们可以通过设置PS1变量来改变bash的提示符内容,如下: 改变了PS1变量的内容后,bash提示符跟着变化了.PS1变量也可以使用反斜杠"\"来显示类似变量的内容,知道反斜杠转义的应该都不陌生,如下: 在PS1中加上"

bash脚本编程基础及配置文件

shell脚本编程: 编程语言的分类:根据运行方式 编译运行:源代码----->编译器(编译)---->程序文件 C语言: 解释运行:源代码--->运行时启动解释器,由解释器边解释边运行: 根据其编程过程中功能的实现是调用库还是调用外部的程序文件: shell脚本编程: 利用系统上的命令及编程组件进行编程: 完成编程: 利用库或编程组件运行编程 编程模型: 过程式编程语言,面向对象的编程语言 程序=指令+数据 过程式:以指令为中心来组织代码,数据是服务于代码: 顺序执行 选择执行 循环执

Linux学习日记--基础命令(7)--bash中的变量,配置文件

变量的定义和使用 变量类型 强类型:定义变量时必须指定类型.参与运算必须符合类型要求:调用未声明变量会产生错误: 弱类型:无须指定类型,默认均为字符型:参与运算会自动进行隐式类型转换:变量无须事先定义可直接调用: 变量命名法则:                1.不能使程序中的保留字:例如if, for;                 2.只能使用数字.字母及下划线,且不能以数字开头:                3.见名知义,         bash中的变量的种类:          

bash启动时加载配置文件过程

本文目录: 1.1 判断是否交互式.是否登录式 1.2 几种常见的bash启动方式 1.3 加载bash环境配置文件 当用户登录系统时,会加载各种bash配置文件,还会设置或清空一系列变量,有时还会执行一些自定义的命令.这些行为都算是启动bash时的过程. 另外,有些时候登录系统是可以交互的(如正常登录系统),有些时候是无交互的(如执行一个脚本),因此总的来说bash启动类型可分为交互式shell和非交互式shell.更细分一层,交互式shell还分为交互式的登录shell和交互式非登录shel

struts2验证规则validation配置文件命名方式总结

1.Action级别校验命名格式: ActionClassName-validation.xml 2.Action中某个方法的校验命名格式: ActionClassName-ActionAliasName-validation.xml 注意:这里的ActionAliasName(action别名)指的是struts.xml中Action name="XX"的xx的名称,而不是method="XX"的名称. 3.如果以上2个校验文件都存在,那么2个文件都会被执行:如果

bash 脚本编程基础及配置文件

Shell脚本编程: 编程语言的分类:根据运行方式 编译运行:源代码->编译器(编译)-- > 程序文件 C语言: 解释运行:源代码->运行时启动解释器,由解释器边解释边运行: 根据器编程过程中功能的实现是调用库函数调用外部的程序文件: shell脚本编程: 利用系统上的命令及编程组件进行编程: 完整编程: 利用库或飙车组件进行编程: 编程模型:过程式编程语言,面向对象的编程语言: 程序=指令+数据 过程式:以指令为中心来组织代码,数据是服务于代码: 顺序执行,现在执行,循环执行 对象式

linux学习19 shell脚本基础-bash脚本编程基础及配置文件

一.shell脚本编程 1.编程语言的分类,根据运行方式 a.编译运行:源代码 --> 编译器(编译) --> 程序文件 C语言: b.解释运行:源代码 --> 运行时启动解释器,由解释器边解释边运行:即源代码本身并不能运行,而是启动一个解释器的进程,把整个源代码的内容当做解释器的参数.因为其是边解释边运行因此运行过程中比起编译运行速度会差一些. c.无论是编译器还是解释器中间总需要另外一个程序,即在运行过程中全程参与,这就是我们说的翻译官,他需要将我们人能识别的代码转换成机器所能识别的