Shell编程之字符截取命令——cut、printf、awk、sed

  • cut、printf和awk三个字段提取命令与grep命令的区别是:grep命令在文件当中提取符合条件的行,cut命令和awk命令提取列。
  • 一般cut不能独立使用,必须管道符和grep命令联合使用;
  • 只有普通用户的权限才是/bin/bash文件,所有系统用户的权限都是/sbin/nilogin文件
1、cut字段提取命令

[root@localhost ~]# cut [选项] 文件名

选项:

  • -f 列号:提出第几列
  • -d 分隔符:按照指定分隔符分割列。默认时候的分隔符是制表符,即“Tab”键

联系测试文件如下:

[root@root ~]# vi student.txt

ID      Name    gender  Mark
1       Liming  M       86
2       SC      M       90
3       Gao     M       83
  • 示例如下:
[root@root ~]# cut -f 2 student.txt
Name
Liming
SC
Gao
[root@root ~]# cut -f 2,3 student.txt
Name	gender
Liming	M
SC	M
Gao	M

注意:/etc/passwd——>是用户信息文件

[root@root ~]# cut -d ":" -f 1,3 /etc/passwd
root:0
bin:1
daemon:2
adm:3
lp:4
sync:5
shutdown:6
... ...

在管道符中使用grep命令和cut命令的示例:

  • cat /etc/passwd ——> 会列出所有的passwd文件;
  • grep /bin/bash ——> 提取所有包含有/bin/bash的行(只有普通用户的权限才是/bin/bash,所有系统用户的权限都是/sbin/nilogin);
  • grep -v root ——> 取反,在这个命令里面提取不包含有root的行;
  • cut -d “:” -f 1 ——>一冒号[ : ]为分割符提取第一列;
[root@root ~]# useradd user1
[root@root ~]# useradd user2
[root@root ~]# useradd user3
#添加普通用户
[root@root ~]# cat /etc/passwd
#通过cat命令读取/etc下的passwd文档
#在/etc/passwd文档内容如下:
... ...
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
user1:x:500:500::/home/user1:/bin/bash
user2:x:501:501::/home/user2:/bin/bash
user3:x:502:502::/home/user3:/bin/bash
[root@root ~]# cat /etc/passwd | grep /bin/bash
root:x:0:0:root:/root:/bin/bash
user1:x:500:500::/home/user1:/bin/bash
user2:x:501:501::/home/user2:/bin/bash
user3:x:502:502::/home/user3:/bin/bash
#grep   /bin/bash ——> 提取所有包含有/bin/bash的行(只有普通用户的权限才是/bin/bash,所有系统用户的权限都是/sbin/nilogin);
[root@root ~]# cat /etc/passwd | grep /bin/bash | grep -v root
user1:x:500:500::/home/user1:/bin/bash
user2:x:501:501::/home/user2:/bin/bash
user3:x:502:502::/home/user3:/bin/bash
#grep   -v   root ——> 取反,在这个命令里面提取不包含有root的行;
[root@root ~]# cat /etc/passwd | grep /bin/bash | grep -v root | cut -d ":" -f 1
user1
user2
user3
#cut   -d   ":"   -f   1 ——>一冒号[ : ]为分割符提取第一列;
#接下来把这个值赋给变量,就可以通过循环删除这些用户了的;
  • cut命令的局限:
  • 如果以空格作为分隔符,cut命令是不能识别的,这是cut命令最大的问题。这时候只能用awk命令。能用cut命令尽量用cut命令,,这个比较简单。
  • cut命令只能识别制表符(Tab键),要么就是有分隔符的具体符号,比如,[: , .]都是可以的。

[root@localhost ~]# df -h | cut -d " " -f 1,3

注意:df命令是查看我们分区的使用状况;

示例如下:

[root@root ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda2        20G  3.6G   15G  20% /
tmpfs           932M  224K  932M   1% /dev/shm
/dev/sda1       985M   46M  889M   5% /boot
/dev/sda3       9.7G  151M  9.0G   2% /home
/dev/sda5       4.9G  138M  4.5G   3% /opt
/dev/sr0        3.6G  3.6G     0 100% /media/RHEL_6.5 x86_64 Disc 1

写一个脚本,用于判断根分区的使用率,如果这个使用率超过80%,让程序报警,告诉管理员硬盘快占满了,需要管理员手工清除。

2、printf命令(格式化打印命令)

严格来讲printf命令并不是字符提取命令,而是应用到awk列提取命令当中的标准输出格式。因此我们学习awk命令之前先学习一下printf命令。

格式:printf ‘输出类型输出格式’ 输出内容

只有加了单元号或双引号,程序才知道不是输出的字符串,而是需要格式化调整的格式符。

输出类型:

  • %ns : 输出字符串。n是数字指代输出几个字符;
  • %ni : 输出整数。n是数字指代输出几个数字;
  • %m.nf : 输出浮点数。m和n是数字,指代输出整数,位数和小数位数。如%8.2f代表共输出8位数,其中2位是小数,6位是整数;

在这里插入图片描述printf基本使用格式符:

基本格式命令:[root@root ~]# printf ‘%s %s %s\n’ 1 2 3 4 5 6

  • ‘%s %s %s\n’ ——> 格式符应该用引号括起来,然后指定我要输出的无内容,如果我们要输出6个字符作为一行,我们就应该写6个%s,如果只写了3个%s系统就认为每3个为一组的形式输出,最后通过\n、\r、\t 来调整输出格式。
    其中,\n、\r、\t 这三个格式是最常用的;

示例如下:

  • [root@localhost ~]# printf %s 1 2 3 4 5 6

输出选项和输出类型并没有用引号括起来的

[root@root ~]# printf %s 1 2 3 4 5  6
123456[root@root ~]# 

#输出选项和输出类型并没有用引号括起来的。它会将123456当成一个完整的字符串输出,
#而且没有任何的格式调整,全部都握在了一起。这就是printf最基本的用法。
  • [root@localhost ~]# printf %s %s %s 1 2 3 4 5 6
[root@root ~]# printf %s %s %s 1 2 3 4 5  6
%s%s123456[root@root ~]# 

#目的:我想把123当成单独的字符串,456也当成单独的字符串输出。
#实际结果:只有把第一个%s当成了输出选项,后面的所有的内容,包括两个%s被当成了字符串,然后原封不动的输出这不符合我们的需求。
#只有加了单元号或双引号,程序才知道输出的%s不是字符串,而是需要格式化调整的格式符。
  • [root@localhost ~]# printf ‘%s%s%s’ 1 2 3 4 5 6
[root@root ~]# printf '%s %s %s' 1 2 3 4 5  6
1 2 34 5 6[root@root ~]# 

#尝试着将123和456分成两组输出,只是没有换行,因为没有换行符。%s之间有空格,程序就知道输出的时候有空格了。怎么让程序知道123是一组,456是一组呢?这时候就要加入换行符来区分。
#只有加了单元号或双引号,程序才知道输出的%s不是字符串,而是需要格式化调整的格式符。
  • [root@localhost ~]# printf ‘%s%s%s\n’ 1 2 3 4 5 6
[root@root ~]# printf '%s %s %s\n' 1 2 3 4 5  6
1 2 3
4 5 6
  • printf命令输出文件内容:
[root@root ~]# cat student.txt
ID	Name	gender	Mark
1	Liming	M	86
2	SC	M	90
3	Gao	M	83
[root@root ~]# printf '%s' student.txt
student.txt[root@root ~]# 
#printf命令这时候输出的并不是文件的内容而是文件名,因为printf命令认为student.txt是输出的字符串。

student.txt[root@root ~]# cat student.txt | printf '%s'
[root@root ~]# 
#printf命令后面不能直接加文件名,也不能通过管道符来接收第一条命令的执行结果。

[root@root ~]# printf '%s' $(cat student.txt)
IDNamegenderMark1LimingM862SCM903GaoM83[root@root ~]# 
# $(cat student.txt)代表我后面执行的内容是一条系统命令 ,先让这一条命令执行,然后通过printf格式化打印这条命令。当然没有调整格式,所以输出是一连串的字符串。

[root@root ~]# printf '%s\t %s\t %s\t %s\n' $(cat student.txt)
ID	 Name	 gender	 Mark
1	 Liming	 M	 86
2	 SC	 M	 90
3	 Gao	 M	 83
3、awk命令

在awk命令的输出中支持print和printf命令:

  • 在awk命令中,我们不能直接调用系统命令cat,也不能直接调用系统命令,我们使用的命令就是printf。
  • print命令:print会在每个输出之后自动加入一个换行符(Linux默认没有print命令);
  • printf命令:printf是标准格式输出命令,并不会自动加入换行符,如果需要换行,必须手动加入换行符;
  • 如果以空格作为分隔符,awk命令可以识别空格作为分隔符的。但是cut命令是不能识别的,这是cut命令最大的问题。这是cut命令的局限性。
  • awk命令也可以使用制表符(Tab键)或者[: , .]这样的分隔符,它的功能比cut命令功能强大。
  • awk命令是一个非常复杂的命令,它不但可以实现字符段的截取。还可以在awk命令中编程调用,如定义函数,进行判断,调用流程控制。也可以成为awk编程。
3.1> awk命令的格式:

# awk ‘条件1{动作1} 条件2{动作2} …’ 文件名

条件(Pattern):

  • 一般使用关系表达式作为条件
  • x > 10 : 判断变量x是否大于10
  • x > 10 : 大于等于
  • x > 10 : 小于等于

动作(Action):

  • 格式化输出。输出某一个内容,
  • 流程控制语句。if,for

关于awk命令说明:

  • 如果符合条件1,就执行动作1;同理,如果符合条件2,就执行动作2。如果没有定义条件,表示不论什么样的数据都执行这个动作,相当于执行文件当中的所有内容。
  • awk命令虽然是列命令,但是它处理数据的时候先读入一行数据,然后把这一行所有的数据都赋给$1($1代表第一列)、$2($2代表第二列)、$3($3代表第三列)…,$0($0代表整个行本身,这一行的所有数据)。然后在判断条件是否符合(这里没有输入任何条件,表示只要数据全部执行这个动作)。
  • awk命令的基本使用,示例说明:
#student.txt文件内容如下:
[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M		82	95	    86	    87.66
2	SC	    M		74	96	    87	    85.66
3	Gao	    M		99	83	    93	    91.66

[root@root ~]# awk '{printf $2 $6}' student.txt
NameMySQLLiming86SC87Gao93[root@root ~]# awk '{printf $2 "\t" $6"\n"}' student.txt
Name	MySQL
Liming	86
SC	    87
Gao	    93
#如果没有定义条件,表示不论什么样的数据都执行这个动作,相当于执行{ }里面文件中的所有内容。
#$2代表文件的第二列,$6代表文件的第六列。这里面printf命令再也不是系统命令,而是awk命令里面的动作命令。

#awk命令虽然是列命令,但是它处理数据的时候先读入一行数据,然后把这一行所有的数据都赋
#给$1($1代表第一列)、$2($2代表第二列)、$3($3代表第二列)...,$0($1代表整个行本身,
#这一行的所有数据)。然后在判断条件是否符合(这里没有输入任何条件,表示只要数据全部执行这
#个动作),我们看到了这个时候先输出$2和$6,这个时候回打印第一行的Name和Average。接着把
#第二行数据读入到awk当中。后面的一次类推。
  • awk命令可以识别空格作为分隔符的,示例如下:
[root@root ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda2        20G  3.6G   15G  20% /
tmpfs           932M   76K  932M   1% /dev/shm
/dev/sda1       985M   46M  889M   5% /boot
/dev/sda3       9.7G  151M  9.0G   2% /home
/dev/sda5       4.9G  138M  4.5G   3% /opt
/dev/sr0        3.6G  3.6G     0 100% /media/RHEL_6.5 x86_64 Disc 1

[root@root ~]# df -h | awk '{print $1 "\t" $5 "\t" $6}'
Filesystem	Use%	Mounted
/dev/sda2	20%	/
tmpfs	1%	/dev/shm
/dev/sda1	5%	/boot
/dev/sda3	2%	/home
/dev/sda5	3%	/opt
/dev/sr0	100%	/media/RHEL_6.5

[root@root ~]# df -h | awk '{printf $1 "\t" $5 "\t" $6 "\n"}'
Filesystem	Use%	Mounted
/dev/sda2	20%	/
tmpfs	1%	/dev/shm
/dev/sda1	5%	/boot
/dev/sda3	2%	/home
/dev/sda5	3%	/opt
/dev/sr0	100%	/media/RHEL_6.5

print和printf的区别:

  • 在系统Linux命令当中,是没有print命令的,只有printf命令。但是在awk命令当中print命令和printf命令都可以使用;
  • 区别就是:printf命令在不会在每行末尾自动加入换行符,需要手工来加入换行符。而print命令会在每行末尾自动加入换行符
  • 提取CPU的使用率,示例如下
[root@root ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda2        20G  3.6G   15G  20% /
tmpfs           932M  224K  932M   1% /dev/shm
/dev/sda1       985M   46M  889M   5% /boot
/dev/sda3       9.7G  151M  9.0G   2% /home
/dev/sda5       4.9G  138M  4.5G   3% /opt
/dev/sr0        3.6G  3.6G     0 100% /media/RHEL_6.5 x86_64 Disc 1
[root@root ~]# df -h | grep sda2
/dev/sda2        20G  3.6G   15G  20% /
[root@root ~]# df -h | grep sda2 | awk '{print $5}'
20%
[root@root ~]# df -h | grep sda2 | awk '{print $5}' | cut -d "%" -f 1
20
3.2> BEGIN命令——作用是开始:

# awk ‘BEGIN {printf “This is a transcript \n” } {printf $2 “\t” $6 “\n”}’ student.txt

关于BEGIN命令的相关解释:

  • BEGIN是指,在所有的数据读取之前,执行{printf “This is a transcript \n” } 的内容,并且{printf “This is a transcript \n” }只执行一次。
  • BEGIN是写在了大括号前的,所以BEGIN是一个条件,只有满足了BEGIN条件,才会执行 {printf “This is a transcript \n” } 里面的动作,接着处理后面的数据。

示例如下:

[root@root ~]# awk 'BEGIN{print "test !"} {print $2 "\t" $5}' student.txt
test !
Name	Linux
Liming	95
SC	96
Gao	83
3.3> FS内置变量

# cat /etc/passwd | grep “/bin/bash” | awk ‘BEGIN {FS=":"} {printf $1 “\t” $3 “\n”}’

FS内置变量的作用是:指定分隔符,默认的分隔符是空格和制表符(Tab键)。

FS内置变量,示例如下:

[root@root ~]# awk '{FS=":"} {print $1 "\t" $3}' /etc/passwd
root:x:0:0:root:/root:/bin/bash	
bin	1
daemon	2
adm	3
... ...
#但是第一行没有处理的,从第二行开始处理。
#awk命令先执行的时候,先读入“root:x:0:0:root:/root:/bin/bash	”数据,然后在执行后面的操作。
#在执行{FS=":"} 分隔符之前,第一行的数据已经读入,因此这个数据的处理已经来不及了。因此,在FS执行之前加入BEGIN变量。

[root@root ~]# awk 'BEGIN{FS=":"} {print $1 "\t" $3}' /etc/passwd
root	0
bin	1
daemon	2
adm	3
lp	4
#在FS执行之前加入BEGIN变量。在读取第一条数据之前,先先把分隔符写进去,接着处理后面的数据。这样所有的数据都按照我们的要求执行了。
3.4> END命令

# awk ‘END{printf “The End \n” } {printf $2 “\t” $6 “\n”}’ student.txt

END命令是指当所有的命令都执行完之后,在执行END后面的动作。

示例如下:

[root@root ~]# awk 'BEGIN{FS=":"} END{print"AAAAAAAAAAAAAAAAA"} {print $1 "\t" $3}' /etc/passwd
... ...
tcpdump	72
user1	500
user2	501
user3	502
AAAAAAAAAAAAAAAAA
#所有的命令处理完之后,会执行一条END命令。
3.5> 关系运算符

# cat student.txt | grep -v Name | \awk ‘$6>=87{printf “\n”}’

示例如下:

[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# cat student.txt | grep -v Name | awk '$6 >= 87{printf $2 "\n"}'
SC
Gao
#[ grep -v Name]反选取消“ID	Name	gender	PHP	Linux	MySQL	Average”行。
#在执行{printf $2 "\n"}内容之前,先判断$6 >= 87知否成立。
4、sed命令

前面三个命令(cut、printf、awk)都是字段截取的。grep命令是进行行截取的,而cut命令和awk命令是进行列截取。

sed命令是一种几乎包括所有UNIX(包括Linux)的轻量级流编辑器。sed主要是对文本或者是文件当中的数据进行选取、替换、删除、新增命令。相当于一个编译器

  • vi命令只能修改文件。但是vi不能够直接修改结果里面的内容,如果要修改命令的输出,先把命令保存到文件当中,然后用vi去修改这个文件。这是vi的局限。
  • sed不但可以修改文件,而且可以通过管道符来接收数据修改 命令的结果。话句话说,不需要将命令的结果先写到文件当中,而是用管道符直接接收直接用sed命令进行编辑。也就是说,sed命令支持管道符操作。
1、sed命令格式:

[root@localhost ~]# sed [选项] ‘[动作]’ 文件名

  • 选项:
  • -n : 一般sed命令会把所有数据都输出到屏幕。如果加入此选择,则只会把经过sed 命令处理的行输出到屏幕。
  • -e : 允许输入数据应用多条sed命令编辑。
  • -i : 用sed的修改结果直接修改读取数据文件(不但进行修改,而且把修改的结果保存到文件当中),而不是由屏幕输出。

关于以上选项的解释:

  • 选项-i,不但进行修改而且把修改的结果保存到文件当中。也就说不加-i,你的数据只是输出的时候进行了改变,但是不会影响原文件里面的数据。如果加了-i,不但输出数据进行了更改,你的源文件数据也会进行更改。
  • 一般情况下,要用p动作(即,打印输出动作)都要跟-n联合使用,否则,会全部打印。
  • 动作:
    在这里插入图片描述(1)示例说明:查看、删除

[root@localhost ~]# sed ‘2p’ student.txt
#查看文件第二行

[root@localhost ~]# sed -n ‘2p’ student.txt

[root@localhost ~]# sed ‘2,4d’ student.txt
#删除第二行到第四行的数据,但不修改文件本身

[root@root ~]# sed '2p' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# sed -n '2p' student.txt
1	Liming	M	82	95	86	87.66
#注意以上命令的输出都不会影响文件的本身,sed命令只要不加-i选项,所有的操作都不影响文件本身。只是影响了屏幕输出。

[root@root ~]# df -h |sed -n '2p'
/dev/sda2        20G  3.6G   15G  20% /
#sed命令可以放在管道符之后处理,接收前一个命令的执行结果。vi就做不到这一点。

[root@root ~]# sed '2,4d' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
[root@root ~]# sed '2,3d' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
3	Gao	M	99	83	93	91.66
[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
#但是文件的内容并没有更改。没有加i选项,仅仅影响的是屏幕输出。

(2)示例说明:追加、插入

[root@localhost ~]# sed ‘2a hello’ student.txt
#在第二行后追加hello

[root@localhost ~]# sed ‘2i hello
world’ student.txt
#在第二行前插入两行数据。其中\表示数据内有输完,还有第二行

[root@root ~]# sed '2a zuobi' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
zuobi
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# sed '2i canglaoshi \
> bolaoshi' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
canglaoshi 
bolaoshi
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
#和上面一样。修改只是命令的输出,没有修改原文件。

(3)示例说明:行替换

[root@localhost ~]# sed ‘2c No such person’ student.txt
#数据替换。动作c是替换整个行。

[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# sed '4c No such person' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
No such person

(4)示例说明:字符串替换

[root@root ~]# sed ‘s/旧字串/新字串/g’ 文件名

例如:
[root@root ~]# sed ‘3s/74/99/g’ student.txt
#在第三行中,把74 换成99
[root@root ~]# [root@root ~]# sed -i ‘3s/74/99/g’ student.txt
#sed操作的数据直接写入文件

[root@root ~]# sed -e ‘s/Liming//g ; s/Gao//g’ student.txt
#同时把“Liming”和“Gao”替换为空

[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# sed '3s/74/99/g' student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	99	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	74	96	87	85.66
3	Gao	M	99	83	93	91.66
[root@root ~]# sed -i  '3s/74/99/g' student.txt
[root@root ~]# cat student.txt
ID	Name	gender	PHP	Linux	MySQL	Average
1	Liming	M	82	95	86	87.66
2	SC	M	99	96	87	85.66
3	Gao	M	99	83	93	91.66
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目 录 译者序 前言 第一部分 shell 第1章 文件安全与权限 1 1.1 文件 1 1.2 文件类型 2 1.3 权限 2 1.4 改变权限位 4 1.4.1 符号模式 4 1.4.2 chmod命令举例 5 1.4.3 绝对模式 5 1.4.4 chmod命令的其他例子 6 1.4.5 可以选择使用符号模式或绝对模式 7 1.5 目录 7 1.6 suid/guid 7 1.6.1 为什么要使用suid/guid 8 1.6.2 设置suid/guid的例子 8 1.7 chown和chgrp 9 1.7.1 chown举例 9 1.7.2 chgrp举例 9 1.7.3 找出你所属于的用户组 9 1.7.4 找出其他用户所属于的组 10 1.8 umask 10 1.8.1 如何计算umask值 10 1.8.2 常用的umask值 11 1.9 符号链接 12 1.9.1 使用软链接来保存文件的多个映像 12 1.9.2 符号链接举例 12 1.10 小结 13 第2章 使用find和xargs 14 2.1 find命令选项 14 2.1.1 使用name选项 15 2.1.2 使用perm选项 16 2.1.3 忽略某个目录 16 2.1.4 使用user和nouser选项 16 2.1.5 使用group和nogroup选项 16 2.1.6 按照更改时间查找文件 17 2.1.7 查找比某个文件新或旧的文件 17 2.1.8 使用type选项 17 2.1.9 使用size选项 18 2.1.10 使用depth选项 18 2.1.11 使用mount选项 18 2.1.12 使用cpio选项 18 2.1.13 使用exec或ok来执行shell命令 19 2.1.14 find命令的例子 20 2.2 xargs 20 2.3 小结 21 第3章 后台执行命令 22 3.1 cron和crontab 22 3.1.1 crontab的域 22 3.1.2 crontab条目举例 23 3.1.3 crontab命令选项 23 3.1.4 创建一个新的crontab文件 24 3.1.5 列出crontab文件 24 3.1.6 编辑crontab文件 24 3.1.7 删除crontab文件 25 3.1.8 恢复丢失的crontab文件 25 3.2 at命令 25 3.2.1 使用at命令提交命令或脚本 26 3.2.2 列出所提交的作业 27 3.2.3 清除一个作业 27 3.3 &命令 27 3.3.1 向后台提交命令 28 3.3.2 用ps命令查看进程 28 3.3.3 杀死后台进程 28 3.4 nohup命令 29 3.4.1 使用nohup命令提交作业 29 3.4.2 一次提交几个作业 29 3.5 小结 30 第4章 文件名置换 31 4.1 使用* 31 4.2 使用? 32 4.3 使用[...]和[!...] 32 4.4 小结 33 第5章 shell输入与输出 34 5.1 echo 34 5.2 read 35 5.3 cat 37 5.4 管道 38 5.5 tee 39 5.6 标准输入、输出和错误 40 5.6.1 标准输入 40 5.6.2 标准输出 40 5.6.3 标准错误 40 5.7 文件重定向 40 5.7.1 重定向标准输出 41 5.7.2 重定向标准输入 42 5.7.3 重定向标准错误 42 5.8 结合使用标准输出和标准错误 43 5.9 合并标准输出和标准错误 43 5.10 exec 44 5.11 使用文件描述符 44 5.12 小结 45 第6章 命令执行顺序 46 6.1 使用&& 46 6.2 使用|| 46 6.3 用()和{ }将命令结合在一起 47 6.4 小结 48 第二部分 文本过滤 第7章 正则表达式介绍 49 7.1 使用句点匹配单字符 50 7.2 在行首以^匹配字符串或字符序列 50 7.3 在行尾以$匹配字符串或字符 51 7.4 使用*匹配字符串中的单字符或其重复 序列 51 7.5 使用\屏蔽一个特殊字符的含义 52 7.6 使用[]匹配一个范围或集合 52 7.7 使用\{\}匹配模式结果出现的次数 53 7.8 小结 55 第8章 grep家族 56 8.1 grep 57 8.1.1 双引号引用 57 8.1.2 grep选项 57 8.1.3 查询多个文件 57 8.1.4 行匹配 57 8.1.5 行数 58 8.1.6 显示非匹配行 58 8.1.7 精确匹配 58 8.1.8 大小写敏感 58 8.2 grep和正则表达式 58 8.2.1 模式范围 59 8.2.2 不匹配行首 59 8.2.3 设置大小写 59 8.2.4 匹配任意字符 59 8.2.5 日期查询 59 8.2.6 范围组合 60 8.2.7 模式出现机率 60 8.2.8 使用grep匹配“与”或者“或”模式 61 8.2.9 空行 61 8.2.10 匹配特殊字符 61 8.2.11 查询格式化文件名 61 8.2.12 查询IP地址 61 8.3 类名 62 8.4 系统grep命令 62 8.4.1 目录 63 8.4.2 passwd文件 63 8.4.3 使用ps命令 63 8.4.4 对一个字符串使用grep 64 8.5 egrep 64 8.6 小结 65 第9章 AWK介绍 66 9.1 调用awk 66 9.2 awk脚本 67 9.2.1 模式和动作 67 9.2.2 域和记录 67 9.2.3 awk中正则表达式及其操作 70 9.2.4 元字符 70 9.2.5 条件操作符 70 9.2.6 awk内置变量 73 9.2.7 NF、NR和FILENAME 74 9.2.8 awk操作符 75 9.2.9 内置的字符串函数 78 9.2.10 字符串屏蔽序列 80 9.2.11 awk输出函数printf 81 9.2.12 printf修饰符 81 9.2.13 awk数组 86 9.3 小结 88 第10章 sed 用法介绍 89 10.1 sed怎样读取数据 89 10.2 调用sed 89 10.2.1 保存sed输出 90 10.2.2 使用sed在文件中查询文本的方式 90 10.2.3 基本sed编辑命令 90 10.3 sed和正则表达式 91 10.4 基本sed编程举例 91 10.4.1 使用p(rint)显示行 91 10.4.2 打印范围 91 10.4.3 打印模式 92 10.4.4 使用模式和行号进行查询 92 10.4.5 匹配元字符 92 10.4.6 显示整个文件 92 10.4.7 任意字符 92 10.4.8 首行 92 10.4.9 最后一行 93 10.4.10 打印行号 93 10.4.11 附加文本 93 10.4.12 创建sed脚本文件 94 10.4.13 插入文本 94 10.4.14 修改文本 95 10.4.15 删除文本 96 10.4.16 替换文本 96 10.5 使用替换修改字符串 97 10.6 将sed结果写入文件命令 97 10.7 从文件中读文本 98 10.8 匹配后退出 98 10.9 显示文件中的控制字符 99 10.10 使用系统sed 99 10.10.1 处理控制字符 99 10.10.2 处理报文输出 101 10.10.3 去除行首数字 101 10.10.4 附加文本 102 10.10.5 从shellsed传值 102 10.10.6 从sed输出中设置shell变量 102 10.11 快速一行命令 102 10.12 小结 103 第11章 合并与分割 104 11.1 sort用法 104 11.1.1 概述 104 11.1.2 sort选项 104 11.1.3 保存输出 105 11.1.4 sort启动方式 105 11.1.5 sort对域的参照方式 105 11.1.6 文件是否已分类 105 11.1.7 基本sort 106 11.1.8 sort分类求逆 106 11.1.9 按指定域分类 106 11.1.10 数值域分类 106 11.1.11 唯一性分类 107 11.1.12 使用k的其他sort方法 108 11.1.13 使用k做分类键排序 108 11.1.14 指定sort序列 108 11.1.15 pos用法 108 11.1.16 使用head和tail将输出分类 109 11.1.17 awk使用sort输出结果 109 11.1.18 将两个分类文件合并 110 11.2 系统sort 110 11.3 uniq用法 111 11.4 join用法 112 11.5 cut用法 114 11.5.1 使用域分隔符 115 11.5.2 剪切指定域 115 11.6 paste用法 116 11.6.1 指定列 116 11.6.2 使用不同的域分隔符 116 11.6.3 paste命令管道输入 117 11.7 split用法 117 11.8 小结 118 第12章 tr用法 119 12.1 关于tr 119 12.1.1 字符范围 119 12.1.2 保存输出 120 12.1.3 去除重复出现的字符 120 12.1.4 删除空行 120 12.1.5 大写到小写 121 12.1.6 小写到大写 121 12.1.7 删除指定字符 121 12.1.8 转换控制字符 122 12.1.9 快速转换 122 12.1.10 匹配多于一个字符 123 12.2 小结 123 第三部分 登录环境 第13章 登录环境 125 13.1 /etc/profile 125 13.2 用户的$HOME.profile 128 13.3 stty用法 129 13.4 创建.logout文件 131 13.5 小结 131 第14章 环境和shell变量 132 14.1 什么是shell变量 132 14.2 本地变量 132 14.2.1 显示变量 133 14.2.2 清除变量 133 14.2.3 显示所有本地shell变量 133 14.2.4 结合变量值 134 14.2.5 测试变量是否已经设置 134 14.2.6 使用变量来保存系统命令参数 135 14.2.7 设置只读变量 135 14.3 环境变量 136 14.3.1 设置环境变量 136 14.3.2 显示环境变量 136 14.3.3 清除环境变量 137 14.3.4 嵌入shell变量 137 14.3.5 其他环境变量 139 14.3.6 set命令 140 14.3.7 将变量导出到子进程 140 14.4 位置变量参数 141 14.4.1 在脚本中使用位置参数 142 14.4.2 向系统命令传递参数 142 14.4.3 特定变量参数 143 14.4.4 最后的退出状态 144 14.5 小结 145 第15章 引号 146 15.1 引用必要性 146 15.2 双引号 146 15.3 单引号 147 15.4 反引号 147 15.5 反斜线 148 15.6 小结 149 第四部分 基础shell编程 第16章 shell脚本介绍 151 16.1 使用shell脚本的原因 151 16.2 脚本内容 151 16.3 运行一段脚本 152 16.4 小结 153 第17章 条件测试 154 17.1 测试文件状态 154 17.2 测试时使用逻辑操作符 155 17.3 字符串测试 155 17.4 测试数值 156 17.5 expr用法 157 17.5.1 增量计数 158 17.5.2 数值测试 158 17.5.3 模式匹配 158 17.6 小结 159 第18章 控制流结构 160 18.1 退出状态 160 18.2 控制结构 160 18.2.1 流控制 161 18.2.2 循环 161 18.3 if then else语句 161 18.3.1 简单的if语句 162 18.3.2 变量值测试 162 18.3.3 grep输出检查 163 18.3.4 用变量测试grep输出 163 18.3.5 文件拷贝输出检查 164 18.3.6 当前目录测试 164 18.3.7 文件权限测试 165 18.3.8 测试传递到脚本中的参数 165 18.3.9 决定脚本是否为交互模式 165 18.3.10 简单的if else语句 166 18.3.11 变量设置测试 166 18.3.12 检测运行脚本的用户 166 18.3.13 将脚本参数传入系统命令 167 18.3.14 null:命令用法 167 18.3.15 测试目录创建结果 168 18.3.16 另一个拷贝实例 169 18.3.17 多个if语句 169 18.3.18 测试和设置环境变量 169 18.3.19 检测最后命令状态 170 18.3.20 增加和检测整数值 171 18.3.21 简单的安全登录脚本 172 18.3.22 elif用法 173 18.3.23 使用elif进行多条件检测 173 18.3.24 多文件位置检测 174 18.4 case语句 175 18.4.1 简单的case语句 175 18.4.2 对匹配模式使用| 176 18.4.3 提示键入y或n 177 18.4.4 case与命令参数传递 177 18.4.5 捕获输入并执行空命令 178 18.4.6 缺省变量值 179 18.5 for循环 180 18.5.1 简单的for循环 181 18.5.2 打印字符串列表 181 18.5.3 对for循环使用ls命令 181 18.5.4 对for循环使用参数 182 18.5.5 使用for循环连接服务器 183 18.5.6 使用for循环备份文件 183 18.5.7 多文件转换 183 18.5.8 多sed删除操作 184 18.5.9 循环计数 184 18.5.10 for循环和本地文档 184 18.5.11 for循环嵌入 185 18.6 until循环 186 18.6.1 简单的until循环 186 18.6.2 监视文件 187 18.6.3 监视磁盘空间 187 18.7 while循环 188 18.7.1 简单的while循环 188 18.7.2 使用while循环读键盘输入 188 18.7.3 用while循环从文件中读取数据 189 18.7.4 使用IFS读文件 189 18.7.5 带有测试条件的文件处理 190 18.7.6 扫描文件行来进行数目统计 191 18.7.7 每次读一对记录 193 18.7.8 忽略#字符 193 18.7.9 处理格式化报表 194 18.7.10 while循环和文件描述符 196 18.8 使用break和continue控制循环 197 18.8.1 break 197 18.8.2 跳出case语句 197 18.8.3 continue 197 18.8.4 浏览文件行 198 18.9 菜单 199 18.10 小结 201 第19章 shell函数 202 19.1 在脚本中定义函数 203 19.2 在脚本中使用函数 203 19.3 向函数传递参数 203 19.4 从调用函数中返回 203 19.5 函数返回值测试 204 19.6 在shell中使用函数 204 19.7 创建函数文件 204 19.8 定位文件 205 19.9 检查载入函数 205 19.10 执行shell函数 205 19.10.1 删除shell函数 206 19.10.2 编辑shell函数 206 19.10.3 函数举例 207 19.10.4 将函数集中在一起 219 19.11 函数调用 219 19.11.1 在脚本中调用函数 219 19.11.2 从函数文件中调用函数 220 19.12 定位文件不只用于函数 222 19.13 小结 223 第20章 向脚本传递参数 224 20.1 shift命令 225 20.1.1 shift命令简单用法 225 20.1.2 命令行输入的最后一个参数 225 20.1.3 使用shift处理文件转换 226 20.2 getopts 229 20.2.1 getopts脚本实例 229 20.2.2 getopts使用方式 231 20.2.3 使用getopts指定变量取值 231 20.2.4 访问取值方式 232 20.2.5 使用getopts处理文件转换 233 20.3 小结 235 第21章 创建屏幕输出 236 21.1 tput用法 236 21.1.1 字符串输出 236 21.1.2 数字输出 237 21.1.3 布尔输出 237 21.2 tput用法 237 21.2.1 设置tput命令 237 21.2.2 使用布尔输出 237 21.2.3 在脚本中使用tput 237 21.2.4 产生转义序列 238 21.2.5 光标位置 239 21.2.6 在屏幕中心位置显示文本 240 21.2.7 查找终端属性 240 21.2.8 在脚本中使用功能键 241 21.2.9 使用颜色 242 21.2.10 产生颜色 243 21.2.11 创建精致菜单 246 21.3 小结 251 第22章 创建屏幕输入 252 22.1 增加记录 252 22.2 删除记录 262 22.3 修改记录 266 22.4 查看记录 270 22.5 小结 273 第23章 调试脚本 274 23.1 一般错误 274 23.1.1 循环错误 274 23.1.2 典型的漏写引号 274 23.1.3 测试错误 274 23.1.4 字符大小写 275 23.1.5 for循环 275 23.1.6 echo 275 23.2 set命令 275 23.3 小结 276 第24章 shell嵌入命令 277 24.1 shell嵌入命令完整列表 277 24.1.1 pwd 277 24.1.2 set 278 24.1.3 times 278 24.1.4 type 278 24.1.5 ulimit 279 24.1.6 wait 279 24.2 小结 279 第五部分 高级shell编程技巧 第25章 深入讨论<< 281 25.1 快速创建一个文件 281 25.2 快速创建打印文档 281 25.3 自动选择菜单 282 25.4 自动ftp传输 283 25.5 访问数据库 286 25.6 小结 288 第26章 shell 工具 289 26.1 创建保存信息的文件 289 26.1.1 使用date命令创建日志文件 289 26.1.2 创建唯一的临时文件 290 26.2 信号 291 26.2.1 杀死一个进程 292 26.2.2 检测信号 293 26.3 trap 294 26.3.1 捕获信号并采取相应的行动 294 26.3.2 捕获信号并采取行动的另 一个例子 295 26.3.3 锁住终端 297 26.3.4 忽略信号 298 26.4 eval 300 26.4.1 执行含有字符串的命令 300 26.4.2 给每个值一个变量名 301 26.5 logger命令 302 26.5.1 使用logger命令 303 26.5.2 在脚本中使用logger命令 303 26.6 小结 305 第27章 几个脚本例子 306 27.1 pingall 306 27.2 backup_gen 306 27.3 del.lines 312 27.4 access.deny 313 27.5 logroll 316 27.6 nfsdown 317 27.7 小结 317 第28章 运行级别脚本 318 28.1 怎么知道系统中是否含有运行 级别目录 318 28.2 确定当前的运行级别 319 28.3 快速熟悉inittab 319 28.4 运行级别 320 28.4.1 各种运行级别 321 28.4.2 运行级别脚本的格式 321 28.4.3 安装运行级别脚本 322 28.5 使用inittab来启动应用程序 323 28.6 启动和停止服务的其他方法 324 28.7 小结 324 第29章 cgi脚本 325 29.1 什么是Web页面? 325 29.2 cgi 325 29.3 连接Web服务器 326 29.4 cgi和HTM脚本 326 29.4.1 基本cgi脚本 326 29.4.2 显示shell命令输出 328 29.4.3 使用SSI 330 29.4.4 访问计数器 330 29.4.5 使用一个链接来显示当前Web 环境变量 332 29.4.6 其他常用的环境变量 334 29.5 get和post方法简介 335 29.5.1 get方法 335 29.5.2 post方法 340 29.5.3 填充列表项 347 29.5.4 自动刷新页面 348 29.6 小结 349 附录 常用shell命令 350
本书共分五部分,详细介绍了shell编程技巧,各种UNIX命令及语法,还涉及了UNIX下的文字处理以及少量的系统管理问题。本书内容全面、文字简洁流畅,适合Shell编程人员学习、参考。 目 录 译者序 前言 第一部分 shell 第1章 文件安全与权限 1 1.1 文件 1 1.2 文件类型 2 1.3 权限 2 1.4 改变权限位 4 1.4.1 符号模式 4 1.4.2 chmod命令举例 5 1.4.3 绝对模式 5 1.4.4 chmod命令的其他例子 6 1.4.5 可以选择使用符号模式或绝对模式 7 1.5 目录 7 1.6 suid/guid 7 1.6.1 为什么要使用suid/guid 8 1.6.2 设置suid/guid的例子 8 1.7 chown和chgrp 9 1.7.1 chown举例 9 1.7.2 chgrp举例 9 1.7.3 找出你所属于的用户组 9 1.7.4 找出其他用户所属于的组 10 1.8 umask 10 1.8.1 如何计算umask值 10 1.8.2 常用的umask值 11 1.9 符号链接 12 1.9.1 使用软链接来保存文件的多个映像 12 1.9.2 符号链接举例 12 1.10 小结 13 第2章 使用find和xargs 14 2.1 find命令选项 14 2.1.1 使用name选项 15 2.1.2 使用perm选项 16 2.1.3 忽略某个目录 16 2.1.4 使用user和nouser选项 16 2.1.5 使用group和nogroup选项 16 2.1.6 按照更改时间查找文件 17 2.1.7 查找比某个文件新或旧的文件 17 2.1.8 使用type选项 17 2.1.9 使用size选项 18 2.1.10 使用depth选项 18 2.1.11 使用mount选项 18 2.1.12 使用cpio选项 18 2.1.13 使用exec或ok来执行shell命令 19 2.1.14 find命令的例子 20 2.2 xargs 20 2.3 小结 21 第3章 后台执行命令 22 3.1 cron和crontab 22 3.1.1 crontab的域 22 3.1.2 crontab条目举例 23 3.1.3 crontab命令选项 23 3.1.4 创建一个新的crontab文件 24 3.1.5 列出crontab文件 24 3.1.6 编辑crontab文件 24 3.1.7 删除crontab文件 25 3.1.8 恢复丢失的crontab文件 25 3.2 at命令 25 3.2.1 使用at命令提交命令或脚本 26 3.2.2 列出所提交的作业 27 3.2.3 清除一个作业 27 3.3 &命令 27 3.3.1 向后台提交命令 28 3.3.2 用ps命令查看进程 28 3.3.3 杀死后台进程 28 3.4 nohup命令 29 3.4.1 使用nohup命令提交作业 29 3.4.2 一次提交几个作业 29 3.5 小结 30 第4章 文件名置换 31 4.1 使用* 31 4.2 使用? 32 4.3 使用[...]和[!...] 32 4.4 小结 33 第5章 shell输入与输出 34 5.1 echo 34 5.2 read 35 5.3 cat 37 5.4 管道 38 5.5 tee 39 5.6 标准输入、输出和错误 40 5.6.1 标准输入 40 5.6.2 标准输出 40 5.6.3 标准错误 40 5.7 文件重定向 40 5.7.1 重定向标准输出 41 5.7.2 重定向标准输入 42 5.7.3 重定向标准错误 42 5.8 结合使用标准输出和标准错误 43 5.9 合并标准输出和标准错误 43 5.10 exec 44 5.11 使用文件描述符 44 5.12 小结 45 第6章 命令执行顺序 46 6.1 使用&& 46 6.2 使用|| 46 6.3 用()和{ }将命令结合在一起 47 6.4 小结 48 第二部分 文本过滤 第7章 正则表达式介绍 49 7.1 使用句点匹配单字符 50 7.2 在行首以^匹配字符串或字符序列 50 7.3 在行尾以$匹配字符串或字符 51 7.4 使用*匹配字符串中的单字符或其重复 序列 51 7.5 使用\屏蔽一个特殊字符的含义 52 7.6 使用[]匹配一个范围或集合 52 7.7 使用\{\}匹配模式结果出现的次数 53 7.8 小结 55 第8章 grep家族 56 8.1 grep 57 8.1.1 双引号引用 57 8.1.2 grep选项 57 8.1.3 查询多个文件 57 8.1.4 行匹配 57 8.1.5 行数 58 8.1.6 显示非匹配行 58 8.1.7 精确匹配 58 8.1.8 大小写敏感 58 8.2 grep和正则表达式 58 8.2.1 模式范围 59 8.2.2 不匹配行首 59 8.2.3 设置大小写 59 8.2.4 匹配任意字符 59 8.2.5 日期查询 59 8.2.6 范围组合 60 8.2.7 模式出现机率 60 8.2.8 使用grep匹配“与”或者“或”模式 61 8.2.9 空行 61 8.2.10 匹配特殊字符 61 8.2.11 查询格式化文件名 61 8.2.12 查询IP地址 61 8.3 类名 62 8.4 系统grep命令 62 8.4.1 目录 63 8.4.2 passwd文件 63 8.4.3 使用ps命令 63 8.4.4 对一个字符串使用grep 64 8.5 egrep 64 8.6 小结 65 第9章 AWK介绍 66 9.1 调用awk 66 9.2 awk脚本 67 9.2.1 模式和动作 67 9.2.2 域和记录 67 9.2.3 awk中正则表达式及其操作 70 9.2.4 元字符 70 9.2.5 条件操作符 70 9.2.6 awk内置变量 73 9.2.7 NF、NR和FILENAME 74 9.2.8 awk操作符 75 9.2.9 内置的字符串函数 78 9.2.10 字符串屏蔽序列 80 9.2.11 awk输出函数printf 81 9.2.12 printf修饰符 81 9.2.13 awk数组 86 9.3 小结 88 第10章 sed 用法介绍 89 10.1 sed怎样读取数据 89 10.2 调用sed 89 10.2.1 保存sed输出 90 10.2.2 使用sed在文件中查询文本的方式 90 10.2.3 基本sed编辑命令 90 10.3 sed和正则表达式 91 10.4 基本sed编程举例 91 10.4.1 使用p(rint)显示行 91 10.4.2 打印范围 91 10.4.3 打印模式 92 10.4.4 使用模式和行号进行查询 92 10.4.5 匹配元字符 92 10.4.6 显示整个文件 92 10.4.7 任意字符 92 10.4.8 首行 92 10.4.9 最后一行 93 10.4.10 打印行号 93 10.4.11 附加文本 93 10.4.12 创建sed脚本文件 94 10.4.13 插入文本 94 10.4.14 修改文本 95 10.4.15 删除文本 96 10.4.16 替换文本 96 10.5 使用替换修改字符串 97 10.6 将sed结果写入文件命令 97 10.7 从文件中读文本 98 10.8 匹配后退出 98 10.9 显示文件中的控制字符 99 10.10 使用系统sed 99 10.10.1 处理控制字符 99 10.10.2 处理报文输出 101 10.10.3 去除行首数字 101 10.10.4 附加文本 102 10.10.5 从shellsed传值 102 10.10.6 从sed输出中设置shell变量 102 10.11 快速一行命令 102 10.12 小结 103 第11章 合并与分割 104 11.1 sort用法 104 11.1.1 概述 104 11.1.2 sort选项 104 11.1.3 保存输出 105 11.1.4 sort启动方式 105 11.1.5 sort对域的参照方式 105 11.1.6 文件是否已分类 105 11.1.7 基本sort 106 11.1.8 sort分类求逆 106 11.1.9 按指定域分类 106 11.1.10 数值域分类 106 11.1.11 唯一性分类 107 11.1.12 使用k的其他sort方法 108 11.1.13 使用k做分类键排序 108 11.1.14 指定sort序列 108 11.1.15 pos用法 108 11.1.16 使用head和tail将输出分类 109 11.1.17 awk使用sort输出结果 109 11.1.18 将两个分类文件合并 110 11.2 系统sort 110 11.3 uniq用法 111 11.4 join用法 112 11.5 cut用法 114 11.5.1 使用域分隔符 115 11.5.2 剪切指定域 115 11.6 paste用法 116 11.6.1 指定列 116 11.6.2 使用不同的域分隔符 116 11.6.3 paste命令管道输入 117 11.7 split用法 117 11.8 小结 118 第12章 tr用法 119 12.1 关于tr 119 12.1.1 字符范围 119 12.1.2 保存输出 120 12.1.3 去除重复出现的字符 120 12.1.4 删除空行 120 12.1.5 大写到小写 121 12.1.6 小写到大写 121 12.1.7 删除指定字符 121 12.1.8 转换控制字符 122 12.1.9 快速转换 122 12.1.10 匹配多于一个字符 123 12.2 小结 123 第三部分 登录环境 第13章 登录环境 125 13.1 /etc/profile 125 13.2 用户的$HOME.profile 128 13.3 stty用法 129 13.4 创建.logout文件 131 13.5 小结 131 第14章 环境和shell变量 132 14.1 什么是shell变量 132 14.2 本地变量 132 14.2.1 显示变量 133 14.2.2 清除变量 133 14.2.3 显示所有本地shell变量 133 14.2.4 结合变量值 134 14.2.5 测试变量是否已经设置 134 14.2.6 使用变量来保存系统命令参数 135 14.2.7 设置只读变量 135 14.3 环境变量 136 14.3.1 设置环境变量 136 14.3.2 显示环境变量 136 14.3.3 清除环境变量 137 14.3.4 嵌入shell变量 137 14.3.5 其他环境变量 139 14.3.6 set命令 140 14.3.7 将变量导出到子进程 140 14.4 位置变量参数 141 14.4.1 在脚本中使用位置参数 142 14.4.2 向系统命令传递参数 142 14.4.3 特定变量参数 143 14.4.4 最后的退出状态 144 14.5 小结 145 第15章 引号 146 15.1 引用必要性 146 15.2 双引号 146 15.3 单引号 147 15.4 反引号 147 15.5 反斜线 148 15.6 小结 149 第四部分 基础shell编程 第16章 shell脚本介绍 151 16.1 使用shell脚本的原因 151 16.2 脚本内容 151 16.3 运行一段脚本 152 16.4 小结 153 第17章 条件测试 154 17.1 测试文件状态 154 17.2 测试时使用逻辑操作符 155 17.3 字符串测试 155 17.4 测试数值 156 17.5 expr用法 157 17.5.1 增量计数 158 17.5.2 数值测试 158 17.5.3 模式匹配 158 17.6 小结 159 第18章 控制流结构 160 18.1 退出状态 160 18.2 控制结构 160 18.2.1 流控制 161 18.2.2 循环 161 18.3 if then else语句 161 18.3.1 简单的if语句 162 18.3.2 变量值测试 162 18.3.3 grep输出检查 163 18.3.4 用变量测试grep输出 163 18.3.5 文件拷贝输出检查 164 18.3.6 当前目录测试 164 18.3.7 文件权限测试 165 18.3.8 测试传递到脚本中的参数 165 18.3.9 决定脚本是否为交互模式 165 18.3.10 简单的if else语句 166 18.3.11 变量设置测试 166 18.3.12 检测运行脚本的用户 166 18.3.13 将脚本参数传入系统命令 167 18.3.14 null:命令用法 167 18.3.15 测试目录创建结果 168 18.3.16 另一个拷贝实例 169 18.3.17 多个if语句 169 18.3.18 测试和设置环境变量 169 18.3.19 检测最后命令状态 170 18.3.20 增加和检测整数值 171 18.3.21 简单的安全登录脚本 172 18.3.22 elif用法 173 18.3.23 使用elif进行多条件检测 173 18.3.24 多文件位置检测 174 18.4 case语句 175 18.4.1 简单的case语句 175 18.4.2 对匹配模式使用| 176 18.4.3 提示键入y或n 177 18.4.4 case与命令参数传递 177 18.4.5 捕获输入并执行空命令 178 18.4.6 缺省变量值 179 18.5 for循环 180 18.5.1 简单的for循环 181 18.5.2 打印字符串列表 181 18.5.3 对for循环使用ls命令 181 18.5.4 对for循环使用参数 182 18.5.5 使用for循环连接服务器 183 18.5.6 使用for循环备份文件 183 18.5.7 多文件转换 183 18.5.8 多sed删除操作 184 18.5.9 循环计数 184 18.5.10 for循环和本地文档 184 18.5.11 for循环嵌入 185 18.6 until循环 186 18.6.1 简单的until循环 186 18.6.2 监视文件 187 18.6.3 监视磁盘空间 187 18.7 while循环 188 18.7.1 简单的while循环 188 18.7.2 使用while循环读键盘输入 188 18.7.3 用while循环从文件中读取数据 189 18.7.4 使用IFS读文件 189 18.7.5 带有测试条件的文件处理 190 18.7.6 扫描文件行来进行数目统计 191 18.7.7 每次读一对记录 193 18.7.8 忽略#字符 193 18.7.9 处理格式化报表 194 18.7.10 while循环和文件描述符 196 18.8 使用break和continue控制循环 197 18.8.1 break 197 18.8.2 跳出case语句 197 18.8.3 continue 197 18.8.4 浏览文件行 198 18.9 菜单 199 18.10 小结 201 第19章 shell函数 202 19.1 在脚本中定义函数 203 19.2 在脚本中使用函数 203 19.3 向函数传递参数 203 19.4 从调用函数中返回 203 19.5 函数返回值测试 204 19.6 在shell中使用函数 204 19.7 创建函数文件 204 19.8 定位文件 205 19.9 检查载入函数 205 19.10 执行shell函数 205 19.10.1 删除shell函数 206 19.10.2 编辑shell函数 206 19.10.3 函数举例 207 19.10.4 将函数集中在一起 219 19.11 函数调用 219 19.11.1 在脚本中调用函数 219 19.11.2 从函数文件中调用函数 220 19.12 定位文件不只用于函数 222 19.13 小结 223 第20章 向脚本传递参数 224 20.1 shift命令 225 20.1.1 shift命令简单用法 225 20.1.2 命令行输入的最后一个参数 225 20.1.3 使用shift处理文件转换 226 20.2 getopts 229 20.2.1 getopts脚本实例 229 20.2.2 getopts使用方式 231 20.2.3 使用getopts指定变量取值 231 20.2.4 访问取值方式 232 20.2.5 使用getopts处理文件转换 233 20.3 小结 235 第21章 创建屏幕输出 236 21.1 tput用法 236 21.1.1 字符串输出 236 21.1.2 数字输出 237 21.1.3 布尔输出 237 21.2 tput用法 237 21.2.1 设置tput命令 237 21.2.2 使用布尔输出 237 21.2.3 在脚本中使用tput 237 21.2.4 产生转义序列 238 21.2.5 光标位置 239 21.2.6 在屏幕中心位置显示文本 240 21.2.7 查找终端属性 240 21.2.8 在脚本中使用功能键 241 21.2.9 使用颜色 242 21.2.10 产生颜色 243 21.2.11 创建精致菜单 246 21.3 小结 251 第22章 创建屏幕输入 252 22.1 增加记录 252 22.2 删除记录 262 22.3 修改记录 266 22.4 查看记录 270 22.5 小结 273 第23章 调试脚本 274 23.1 一般错误 274 23.1.1 循环错误 274 23.1.2 典型的漏写引号 274 23.1.3 测试错误 274 23.1.4 字符大小写 275 23.1.5 for循环 275 23.1.6 echo 275 23.2 set命令 275 23.3 小结 276 第24章 shell嵌入命令 277 24.1 shell嵌入命令完整列表 277 24.1.1 pwd 277 24.1.2 set 278 24.1.3 times 278 24.1.4 type 278 24.1.5 ulimit 279 24.1.6 wait 279 24.2 小结 279 第五部分 高级shell编程技巧 第25章 深入讨论<< 281 25.1 快速创建一个文件 281 25.2 快速创建打印文档 281 25.3 自动选择菜单 282 25.4 自动ftp传输 283 25.5 访问数据库 286 25.6 小结 288 第26章 shell 工具 289 26.1 创建保存信息的文件 289 26.1.1 使用date命令创建日志文件 289 26.1.2 创建唯一的临时文件 290 26.2 信号 291 26.2.1 杀死一个进程 292 26.2.2 检测信号 293 26.3 trap 294 26.3.1 捕获信号并采取相应的行动 294 26.3.2 捕获信号并采取行动的另 一个例子 295 26.3.3 锁住终端 297 26.3.4 忽略信号 298 26.4 eval 300 26.4.1 执行含有字符串的命令 300 26.4.2 给每个值一个变量名 301 26.5 logger命令 302 26.5.1 使用logger命令 303 26.5.2 在脚本中使用logger命令 303 26.6 小结 305 第27章 几个脚本例子 306 27.1 pingall 306 27.2 backup_gen 306 27.3 del.lines 312 27.4 access.deny 313 27.5 logroll 316 27.6 nfsdown 317 27.7 小结 317 第28章 运行级别脚本 318 28.1 怎么知道系统中是否含有运行 级别目录 318 28.2 确定当前的运行级别 319 28.3 快速熟悉inittab 319 28.4 运行级别 320 28.4.1 各种运行级别 321 28.4.2 运行级别脚本的格式 321 28.4.3 安装运行级别脚本 322 28.5 使用inittab来启动应用程序 323 28.6 启动和停止服务的其他方法 324 28.7 小结 324 第29章 cgi脚本 325 29.1 什么是Web页面? 325 29.2 cgi 325 29.3 连接Web服务器 326 29.4 cgi和HTM脚本 326 29.4.1 基本cgi脚本 326 29.4.2 显示shell命令输出 328 29.4.3 使用SSI 330 29.4.4 访问计数器 330 29.4.5 使用一个链接来显示当前Web 环境变量 332 29.4.6 其他常用的环境变量 334 29.5 get和post方法简介 335 29.5.1 get方法 335 29.5.2 post方法 340 29.5.3 填充列表项 347 29.5.4 自动刷新页面 348 29.6 小结 349 附录 常用shell命令 350

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值