bash的字符串处理工具:

字符串切片:

${#var}:返回字符串变量var的长度

[root@localhost ~]# num=123456789[root@localhost ~]# echo ${#num}9

${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最          后的部分,offset的取值在0 到${#var}-1 之间(bash4.2后,允许为负值)

[root@localhost ~]# echo ${num:3}456789

${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

[root@localhost ~]# echo ${num:3:4}4567

${var: -lengh}:取字符串的最右侧几个字符:

    注意:冒号后必须有一空白字符

[root@localhost ~]# echo ${num: -3}789

基于模式取子串:

${var#*word}:其中word可以是指定的任意字符

  功能:自左而右,查找var变量所存储的字符串中,第一次出现的word, 删除字符串开头至第一次        出现word字符之间的所有字符

${var##*word}:同上,不同的是,删除的是字符串开头至最后一次由word指定的字符之间的所有内容

[root@localhost ~]# user=`head -1 /etc/passwd`[root@localhost ~]# echo $userroot:x:0:0:root:/root:/bin/bash[root@localhost ~]# echo ${user#*/}root:/bin/bash[root@localhost ~]# echo ${user##*/}bash

${var%word*}:其中word可以是指定的任意字符;

  功能:自右而左,查找var变量所存储的字符串中,第一次出现的word, 删除字符串最后一个字符向       左至第一次出现word字符之间的所有字符;

${var%%word*}:同上,只不过删除字符串最右侧的字符向左至最后一次出现word字符之间的所有字符;

[root@localhost ~]# echo ${user%/*}root:x:0:0:root:/root:/bin[root@localhost ~]# echo ${user%%/*}root:x:0:0:root:

查找替换:

${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替                换之

[root@localhost ~]# echo ${user/root/super}super:x:0:0:root:/root:/bin/bash

${var//pattern/substi}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi                 替换之

[root@localhost ~]# echo ${user//root/super}super:x:0:0:super:/super:/bin/bash

${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替                 换之

[root@localhost ~]# echo ${user/#root/super}super:x:0:0:root:/root:/bin/bash

${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替                 换之

[root@localhost ~]# echo ${user/%bash/nologin}root:x:0:0:root:/root:/bin/nologin

查找并删除:

${var/pattern}:查找var所表示的字符串中,删除第一次被pattern所匹配到的字符串

${var//pattern}:查找var所表示的字符串中,删除所有被pattern所匹配到的字符串

${var/#pattern}:查找var所表示的字符串中,删除行首被pattern所匹配到的字符串

${var/%pattern}:查找var所表示的字符串中,删除行尾被pattern所匹配到的字符串

[root@localhost ~]# echo ${user/root}:x:0:0:root:/root:/bin/bash[root@localhost ~]# echo ${user//root}:x:0:0::/:/bin/bash[root@localhost ~]# echo ${user/#root}:x:0:0:root:/root:/bin/bash

字符大小写转换:

${var^^}:把var中的所有小写字母转换为大写

[root@localhost ~]# echo ${user^^}ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH

${var,,}:把var中的所有大写字母转换为小写

[root@localhost ~]# name=ToM[root@localhost ~]# echo ${name,,}tom

变量赋值:

${var:-value}:如果var为空或未设置,那么返回value;否则,则返回var的值

[root@localhost ~]# echo $num[root@localhost ~]# echo ${num:-123}123[root@localhost ~]# num=5[root@localhost ~]# echo ${num:-123}5

${var:+value}:如果var不空,则返回value

[root@localhost ~]# echo ${num:+123}123

${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则,则返回var的值

[root@localhost ~]# unset num[root@localhost ~]# echo ${num:=123}123[root@localhost ~]# echo $num123[root@localhost ~]# echo ${num:=1234}123

${var:?error_info}:如果var为空或未设置,那么返回error_info;否则,则返回var的值

[root@localhost ~]# unset num[root@localhost ~]# echo ${num:?error_info}-bash: num: error_info[root@localhost ~]# num=123[root@localhost ~]# echo ${num:?error_info}123

为脚本程序使用配置文件,实现变量赋值

  (1) 定义文本文件,每行定义“name=value”

  (2) 在脚本中source此文件即可

高级变量用法-有类型变量

Shell变量一般是无类型的,但是bash Shell提供了declare和typeset两个命令用于指定变量的类型,两个命令是完全等价的

declare [选项] 变量名

选项:

    -r 将变量设置为只读属性

    -i 将变量定义为整型数

    -a 将变量定义为数组

    -f 显示此脚本前定义过的所有函数名及其内容

    -F 仅显示此脚本前定义过的所有函数名

    -x 将变量声明为环境变量

    -l 将变量值转为小写字母

    -u 将变量值转为大写字母

间接变量引用

如果第一个变量的值是第二个变量的名字,从第一个变量引用第二个变量的值就称为间接变量引用

variable1=variable2

variable2=value

variable1的值是variable2,而variable2又是变量名,variable2的值为value,间接变量引用是指通过variable1获得变量值value的行为

bash Shell提供了两种格式实现间接变量引用

  eval tempvar=\$$variable1

  tempvar=${!variable1}

示例:

[root@localhost ~]# name1=tom[root@localhost ~]# name2=name1[root@localhost ~]# name=${!name2}[root@localhost ~]# echo $nametom[root@localhost ~]# eval Name=\$$name2[root@localhost ~]# echo $Name tom

eval命令

eval命令将会首先扫描命令行进行所有的置换,然后再执行该命令。该命令适用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。

示例:

[root@localhost ~]# a=pwd[root@localhost ~]# echo $apwd[root@localhost ~]# eval $a/root

创建临时文件

mktemp命令:创建的临时文件可避免冲突

语法:mktemp[OPTION]... [TEMPLATE]

   

   TEMPLATE: filename.XXX

   X至少要出现三个

OPTION:

  -d: 创建临时目录

  --tmpdir=/DIR:指明临时文件所存放的目录位置

注意:mktemp会将创建的临时文件名直接返回,因此可通过命令引用保存起来

示例:

[root@localhost ~]# mktemp --tmpdir=/tmp file.XXX/tmp/file.QW1

安装复制文件

install命令:

语法格式:

单源复制

    install [OPTION]... [-T] SOURCE DEST 单文件

 

多源复制

     install [OPTION]... SOURCE... DIRECTORY

    install [OPTION]... -t DIRECTORY SOURCE...

创建目录

    install [OPTION]... -d DIRECTORY...创建空目录

   在前两种格式中,会将<来源>复制至<目的地>或将多个<来源>文件复制至已存在的<目录>,同时设定权限模式及所有者/所属组。在第三种格式中,会创建所有指定的目录及它们的主目录。长选项必须用的参数在使用短选项时也是必须的。

常用选项:

    -m,--mode=MODE 设定目标文件权限,默认755

    -o,--owner=OWNER 设定文件属主

    -g,--group=GROUP 设定文件属组

bash特性:

bash如何展开命令行

  • 把命令行分成单个命令词

  • 展开别名

  • 展开大括号种的声明({})

  • 展开波浪符声明(~)

  • 命令替换$()和``)

  • 再次把命令行分成命令词

  • 展开文件通配(*、?、[abc]等等)

  • 准备I/0重导向(<、>)

  • 运行命令

防止扩展

  • 反斜线(\)会使随后的字符按原意解释

       $echo Yourcost:\$5.00

       Yourcost:$5.00

  • 加引号来防止扩展

  • 单引号(’)防止所有扩展

  • 双引号(”)也防止所有扩展,但是以下情况例外:

  • $(美元符号)-变量扩展

  • `(反引号)-命令替换

  • \(反斜线)-禁止单个字符扩展

  • !(叹号)-历史命令替换

bash的配置文件

按生效范围划分,存在两类:

全局配置:

  /etc/profile

  /etc/profile.d/*.sh

  /etc/bashrc

个人配置:

  ~/.bash_profile

  ~/.bashrc

shell登录两种方式

  • 交互式登录:

  (1)直接通过终端输入账号密码登录;

  (2)使用“su-UserName”切换的用户

    执行顺序:

    /etc/profile --> /etc/profile.d/*.sh --> ~/.bash_profile--> ~/.bashrc--> /etc/bashrc

  • 非交互式登录:

  (1)suUserName

  (2)图形界面下打开的终端

  (3)执行脚本

  执行顺序:

    ~/.bashrc--> /etc/bashrc--> /etc/profile.d/*.sh

Profile类

  • 按功能划分,存在两类:

    profiile类和bashrc类

  • profile类:为交互式登录的shell提供配置

    全局:/etc/profile, /etc/profile.d/*.sh

    个人:~/.bash_profile

    功用:

     (1) 用于定义环境变量

     (2) 运行命令或脚本

Bashrc类

  • bashrc类:为非交互式和交互式登录的shell提供配置

 全局:/etc/bashrc

 个人:~/.bashrc

  功用:

   (1) 定义命令别名和函数

   (2) 定义本地变量

   

编辑配置文件生效

  • 修改profile和bashrc文件后需生效

  两种方法:

    1重新启动shell进程

    2 . 或source

例:

[root@localhost ~]# . ~/.bashrc

Bash 退出任务

  • 保存在~/.bash_logout文件中(用户)

  • 在退出登录shell时运行

  • 用于

   ①创建自动备份

   ②清除临时文件

练习:

1、让用户(管理员或所有用户)的PATH环境变量的值多出一个路径,例如多如/usr/local/apache2/bin

[root@localhost ~]# vim /etc/profile.d/http2.sh       PATH=$PATH:/usr/local/http2/bin/

    重启生效,或使用source或 . /etc/profile.d/http2.sh

2、用户wang登录时自动启用别名rm=‘rm –i’

[root@localhost ~]# vim /home/wang/.bashrcalias rm='rm -i'

3、用户登录时,显示红色字体的警示提醒信息“Dangerous”

[root@localhost ~]# vim /etc/profile.d/login.shecho -e "\033[31mDangerous \033[0m"