本人新人小白,正在学习shell编程,如果文章中有错误的地方,欢迎大家指正,谢谢大家_
1、 下列正则表达式匹配什么
x*
:匹配0个或若干个x。
Xx*
:匹配一个X和0个或若干个x。
x\{1,5\}
:匹配1-5个连续的x。
x\{10\}
:匹配10个连续的x。
[0-9]
:匹配带1个数字的行。
[0-9]*
: 匹配0个或若干个数字。
[0-9][0-9][0-9]
:匹配带3个数字的行。
[0-9]\{3\}
:匹配3个连续的数字。
[0-9]\{3,5\}
:匹配3-5个数字的序列。
[0-9]\{1,3\},[0-9]\{3\}
:无法匹配?
^\...
:匹配以三个句点开头的行。
[A-Za-z_][A-Za-z_0-9]*
:匹配一个下划线或字母和0个或多个字母或下划线或数字。
\([A-Za-z0-9]\{1,\}\)\1
:匹配至少一个连续的字母或数字,并将匹配的序列存到1号寄存器中。
^Begin$
:匹配只有Begin的行。
^\(.\).*\1$
:匹配一行中第一个字符和最后一个字符相同的行。
2、 下面命令的作用是什么
who | grep 'mary'
:查出所有用户名带mary的已登录用户。
who | grep '^mary'
:查出所有用户名以mary开头的已登录用户。
grep '[Uu]nix' ch?/*
:在当前目录下以ch开头并且后面只有一个任意字符的文件夹下的所有文件中搜索单词unix或Unix。
ls –l | sort +4n
(新版的shell命令为ls -l | sort -k 5
):对命令ls –l的输出结果按第5个字段的值进行排序。
sed '/^$/d' text > text.out
:删除text中不包含任何字符的行,并将输出结果保存至text.out。
sed 's/\([Uu]nix\)/\1(TM)/g' text > text.out
:将text中所有的unix替换为unix™,所有的Unix替换为Unix™,并将替换后的结果保存至text.out。
date | cut –c12-16
:将date命令的输出中的第12-16列析取处来
date | cut –c5-11, 25- | sed 's/\([0-9]\{1,2\}\)/\1,/'
: 将date命令的输出中的第5-11列和第25到行尾的字符析取处来后,把结果中第一个有1-2个连续数字的序列后面添加一个逗号。
3、 写出实现下列功能地命令
a. 查出所有用户名至少有4个字符地已登录用户:who | cut -c1-8 | grep '.*\{2,\}'
b. 查出系统中所有用户标识号大于99的用户:
cat /etc/passwd | awk -F ':' '{if ($3>99) print $1}'
c. 系统中用户标识号大于99的用户数:
cat /etc/passwd | awk -F ':' '{if ($3>99) print $1}' | wc -l
d. 按文件大小的降序列出目录中的所有文件:
ls -l | sort -nrk 5