本文所选的例子来自于《Advanced Bash-scripting Gudie》一书,译者 杨春敏 黄毅
ABS书上的例子:
代码块和I/O重定向
#!/bin/bash
#从/etc/fstab中读行
File=/etc/fstab
{
read line1
read line2
} < $File
echo "First line in $File is:"
echo "$line1"
echo
echo "Second line in $File is:"
echo "$line2"
exit 0
#现在,你怎么分析每行的分割域
#暗示:使用awk
实践证明,当/etc/fstab文件最开始有空格或者注释的时候,打印出来的要么是空白,要么是一个#,ABS是这样提示的:Now, how do you parse the separate fields of each line?Hint: use awk, or . . .Hans-Joerg Diers suggests using the "set" Bash builtin。大意是:现在,你怎么分析每行之间的分隔域?提示:运用awk,或...Hans-Joerg Diers建议用set这个bash内建命令。
说实在的,我不明白为什么使用awk,因为awk是截取列的,现在要读取的是行,对于set,我也是知之甚少。鉴于这种情况,我将此脚本做了一定的改写,让这个脚本打印的是非空白和注释的行。也许以后,随着shell知识的不断增长,改进后的脚本势必会重新改写。也期待着那一天的到来。
一个改进的脚本
#!/bin/bash
#从/etc/fstab中读取行
printf "$(cat /etc/fstab | sed '/^$/d' | grep -v "^#")\n" > file
File=/root/sh/file
{
read line1
read line2
} < $File
echo "First line in $File is:"
echo "$line1"
echo
echo "Second line in $File is:"
echo "$line2"
echo
exit 0
注意我将/etc/fstab下非空白和注释的行重定向到file文件中,再从file文件中读取。
去除空白行的几种方法:
1.grep命令
grep -v "^$" 文件名
2.sed命令
cat 文件名 | sed '/^$/d'
3.awk命令
cat 文件名 | awk '{if($0!="")print}'
cat 文件名 | awk '{if(length!=0)print $0}'
脚本运行结果