bash的基本特性(3)
1、提供了编程环境
程序编程风格:
过程式:以指令为中心,数据服务于指令;
对象式:以数据为中心,指令服务于数据;
shell程序:提供了编程能力,解释执行;过程式、解释执行;
过程式编程:
顺序执行;
循环执行;
选择执行;
shell脚本:文本文件
shebang:
#!/bin/bash
#!/usr/bin/python
#!/usr/bin/perl
运行脚本:
1、给予执行权限,通过具体的文件路径指定文件执行;
2、直接运行解释器,将脚本作为解释器程序的参数运行;
变量:
命名的内存空间;
编程语言:
强类型:
弱类型:bash
把所有要存储的数据统统当作字符进行;
不支持浮点数;
逻辑运算:
与 &&:第一执行成功了,第二个也执行;第一个执行失败了,第二个就不执行;
或 ||:第一个执行成功了,第二个不执行;第一个执行失败了,第二个执行;
非
异或
示例:ls /var &> /dev/null && echo "sucess" || echo "failure"
grep:
Linux上文本处理三剑客:
grep:文本过滤(模式:pattern)工具;
grep, egrep, fgrep(fast grep)
sed:stream editor,文本编辑工具;
awk:Linux上的实现gawk,文本报告生成器;
grep:Global search REgular expression and Print out the line.
作用:文本搜索工具,根据用户指定的“模式”对目标文本逐行进行匹配检查;打印匹配到的行;
模式:由正则表达式字符及文本字符所编写的过滤条件; 注:如果存在空白字符,必须要用引号引起来
REGEXP分为两类:
基本正则表达式:BRE
扩展正则表达式:ERE
正则表达式引擎:
grep [OPTIONS] PATTERN [FILE...]
选项:
--color=auto:对匹配到的文本着色显示:
-v:显示不能够被pattern匹配到的行;即取反;
-i:忽略字符大小写;
-o:仅显示匹配到的字符串;
-q:静默模式,不输出任何信息;
-A #:after,后#行;
-B #:before,前#行;
-C #:context,前后各#行;
基本正则表达式元字符:
.*:任意长度任意字符;
\?:匹配其前面的字符0或1次;即前面可有可无
\+:匹配其前面的字符至少1次;
\{m\}:匹配其前面字符m次;
\{m,n\}:匹配前面字符至少m次,最多n次;
\{0,n\}:匹配前面的字符至多n次;
\{m,\}:匹配前面字符至少m次;
位置锚定:
^:行首锚定;
$:行尾锚定;
^$:空行;
\< 或 \b:词首锚定;
\> 或 \b:词尾锚定;
分组:
\(\):将一个或多个字符捆绑在一起,当作一个整体进行处理;
Note:分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命令方式为:\1, \2, \3, .....
\1:从左侧起,第一个左括号以及与之匹配右括号之间的模式所匹配到的字符;
\(ab\+\(xy\)*\)
\1:ab\+\(xy\)*
\2:xy
后向引用:引用前面的分组括号中的字符所匹配到的字符。
grep '\([[:alpha:]]\{1,3\}t\>\).*\1' /etc/passwd
练习:
1、显示/proc/meminfo文件中以大小s开头的行;(要求:使用两种方式)
2、显示/etc/passwd文件中不以/bin/bash结尾的行;
3、显示/etc/passwd文件中ID号最大的用户的用户名;
4、如果用户root存在,显示其默认的shell程序;
5、找出/etc/passwd中的两位或三位数;
6、显示/etc/rc.d/rc.sysinit文件中,至少以一个空白字符开头的且后面存在非空白字符的行;
7、找出"netstat -tan“命令的结果中以"LISTEN"后跟0、1或多个空白字符结尾的行;
8、添加用户bash、testbash、basher以及nologin(其shell为/sbin/nologin);而后找出/etc/passwd文件中用户名同shell名的行;
练习:
1、写一个脚本,实现如下功能
如果user1用户存在,就显示其存在,否则添加之;
2、写一个脚本,完成如下功能
如果root用户登录了当前系统,就显示root用户在线;否则说明其未登录;