自动化运维之shell引号和正则表达式(二)
1 shell引号
1)反斜线\
转译
echo * 显示当前目录中所有的文件列表
echo \* 显示*字符
换行
find / \ 换行输入多行命令
> -name "test.txt" \
> -type f \
> -size +5M
find / -name "test.txt" -type f -size +5M
2)单引号''
单引号将它中间的所有任意字符还原为字面意义,实现屏蔽shell元字符的功能,单引号必须成对出现。
echo ‘$HOME’
echo 'test\'
3)双引号""
双引号类似于单引号,不会屏蔽` \ $ 这三个shell元字符的含义,如果需要屏蔽需要前面加一个\符号,其他字符的功能将被屏蔽(包括单引号)。两个双引号之间的单引号不必成对出现
[root@localhost ~]# echo $HOME
/root
[root@localhost ~]# echo "$HOME"
/root
[root@localhost ~]# echo "\$HOME"
$HOME
[root@localhost ~]# echo "this's a book"
this's a book
4)反引号``
shell中使用反引号进行命令替换,命令替换使shell可以将命令字符替换成命令执行结果的输出内容,也可用$()来实现
echo “today is `date +%D`”
echo "today is $(date +%D)"
2 正则表达式
正则表达式中有些匹配字符与shell中的通配符符号一样,但是含义不同
基本正则表达式:grep egrep vi sed awk
扩展正则表达式: egrep awk
基本正则表达式及其所对应的含义
c 匹配字母c
. 匹配任意单个字符
* 匹配前一个字符出现0次或者多次
.* 匹配任意多个任意字符
[] 匹配金河中的任意单个字符,括号中为一个集合
[x-y] 匹配连续的字串范围
^ 匹配字串的开头
$ 匹配字串的结尾
[^] 匹配否定,对括号的集合取反
\ 匹配转译后的字串
\{n,m\} 匹配前一个字符重复n到m次
\{n,\} 匹配前一个字符重复至少n次
\{n\} 匹配前一个字符重复n次
\(\) 将\(与\)之间的内容存储在“保留空间”,最大存储9个
\n 通过\1至\9调用保留空间中的内容,一般和上面的\(\)配合使用
基本正则表达式案例
grep o[os]t /etc/passwd 查找包含oot或者ost的行
grep [0-9] /etc/passwd 查找包含数字0-9的行
grep sbin/[^n] /etc/passwd 查找sbin/后面不跟n的行
grep ‘0\{1,2\}’ /etc/passwd 查找数字0出现1次到2次的行
grep "\(root\)\(:\).*\2\1" /etc/passwd 查找包含以root:开头并以:root结尾的字串行
扩展正则表达式
{n,m} 等同于基本正则表达式的\{n,m\}
+ 匹配前一个字符出现一次或多次
? 匹配前一个字符出现0次或一次
| 匹配逻辑或者,即匹配|前或后的字串
() 匹配正则集合
egrep '0{1,2}' /etc/passwd 查找数字0出现1次和2次的行
egrep '0+' /etc/passwd 查找包含至少一个0的行
egrep '(root|admin)' /etc/passwd 查找包含root或者admin的行
字符集
[:alpha:] 字母字符
[:alnum:] 字母和数字字符
[:cntrl:] 控制字符
[:digit:] 数字符号
[:xdigit:] 十六进制数字字符
[:punct:] 标点符号
[:graph:] 非空格字符
[:print:] 任何可以显示的字符
[:space:] 任何产生空白的字符
[:blank:] 空格和Tab键字符
[:lower:] 小写字母
[:upper:] 大写字母
grep [[:digit:]] /etc/passwd
自动化运维之shell引号和正则表达式(二)的更多相关文章
- 自动化运维工具——puppet详解(二)
一.class 类 1)什么是类? 类是puppet中命名的代码模块,常用于定义一组通用目标的资源,可在puppet全局调用: 类可以被继承,也可以包含子类: 具体定义的语法如下: class NAM ...
- 自动化运维之shell通配符,转义符,和元字符(二)
1 shell通配符 通配符看起来有点象正则表达式语句,但是它与正则表达式不同的,不能相互混淆.把通配符理解为shell特殊代号字符就可. 二.shell元字符 shell除了有通配符之外,由shel ...
- 自动化运维工具——ansible详解(二)
Ansible playbook 简介 playbook 是 ansible 用于配置,部署,和管理被控节点的剧本. 通过 playbook 的详细描述,执行其中的一系列 tasks ,可以让远端主机 ...
- 自动化运维工具——ansible命令使用(二)
一.Ansible系列命令使用 ansible命令执行过程 1 . 加载自己的配置文件 默认/etc/ansible/ansible.cfg 2 . 加载自己对应的模块文件,如command 3 . ...
- 自动化运维:(1)认识 Shell
目录 (一)运维是什么? (二)什么是 Shell? (三)Shell的分类 (四)Shell脚本 (五)Shell的变量 (六)表达式 (七)Linux常见符号 (八)常见命令 (一)自动化运维是什 ...
- Linux Shell交互式自动化运维程序
Expect是Linux操作系统下的一个用来处理交互操作,系统默认是没有安装expect库,所以执行expect会提示找不到命令,需要手动安装,其它安装也比较简单,可以通过二进制源码包编译配置进行安装 ...
- 自动化运维—tomcat服务起停(mysql+shell+django+bootstrap+jquery)
项目简介: 项目介绍:自动化运维是未来的趋势,最近学了不少东西,正好通过这个小项目把这些学的东西串起来,练练手. 基础架构: 服务器端:web框架-Django 前端:html css jQuery ...
- 简单的自动化运维工具(shell+except+whiptail+功能模块化函数+循环)
简单的自动化运维工具(shell+except+whiptail+功能模块化函数+循环) http://www.cnblogs.com/M18-BlankBox/p/5881700.html
- 企业级自动化运维工具---puppet详解
本文收录在Linux运维企业架构实战系列 1.认识puppet 1.1 引入 puppet是什么,咱们先不用专业的名词解释它,咱们先描述一些工作场景,看明白这些工作场景,自然会知道puppet是什么. ...
随机推荐
- JavaScript中,关于class的调用
PS:class的调用,其实是可以叠加的,当然了这要求样式不同的情况下,如果样式相同,则后一个样式会覆盖前一个样式. 1.举例如下: <div id="test" class ...
- 详解ASP.NET缓存机制
文中对ASP.NET的缓存机制进行了简述,ASP.NET中的缓存极大的简化了开发人员的使用,如果使用得当,程序性能会有客观的提升.缓存是在内存存储数据的一项技术,也是ASP.NET中提供的重要特性之一 ...
- SetForegroundWindow、SetActiveWindow、SetFocus 如何将一个某个窗口提到最顶层
http://hi.baidu.com/gookings/item/2b7912ca8d5b3625a0b50aa2 SetForegroundWindow 函数功能:该函数将创建指定窗口的线程设置到 ...
- PL/SQL学习笔记(四)之——删除重复记录
例:假设员工表中有若干记录重复,请删除重复的记录(某企业面试题) ------模拟建表 create table employee( e_id varchar2(20) primary key, e_ ...
- MySQL优化汇总
1)mysql优化汇总,转载自网络
- LR中常见请求的使用示例
Action(){ //application/x-www-form-urlencoded //application/json //web_add_auto_header("Content ...
- 51Nod 1007 正整数分组 -简单DP
题意: 将一堆正整数分为2组,要求2组的和相差最小. 例如:1 2 3 4 5,将1 2 4分为1组,3 5分为1组,两组和相差1,是所有方案中相差最少的. N<=100 sum<=100 ...
- CPP-基础:内部函数应该在当前源文件中说明和定义
static函数与普通函数作用域不同,仅在本文件.只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义.对于可在当前源文件以外使用的函数,应该在一个头文件 ...
- Bootstrap历练实例:表单帮助文件
Bootstrap表单控件可以在输入框input上有一个块级帮助文本,为了添加一个占用整个宽度的内容块,请在input后添加help-block. 实例: <!DOCTYPE html>& ...
- luogu 2296 寻找道路 (搜索)
luogu 2296 寻找道路 题目链接:https://www.luogu.org/problemnew/show/P2296 从终点bfs或者dfs,找出所有终点能到达的点. 然后再从1到n看一下 ...