📄 ch27_06.htm
字号:
<HTML><!--Distributed by F --><HEAD><TITLE>[Chapter 27] 27.6 Fast grep Isn't </TITLE><METANAME="DC.title"CONTENT="UNIX Power Tools"><METANAME="DC.creator"CONTENT="Jerry Peek, Tim O'Reilly & Mike Loukides"><METANAME="DC.publisher"CONTENT="O'Reilly & Associates, Inc."><METANAME="DC.date"CONTENT="1998-08-04T21:44:22Z"><METANAME="DC.type"CONTENT="Text.Monograph"><METANAME="DC.format"CONTENT="text/html"SCHEME="MIME"><METANAME="DC.source"CONTENT="1-56592-260-3"SCHEME="ISBN"><METANAME="DC.language"CONTENT="en-US"><METANAME="generator"CONTENT="Jade 1.1/O'Reilly DocBook 3.0 to HTML 4.0"><LINKREV="made"HREF="mailto:online-books@oreilly.com"TITLE="Online Books Comments"><LINKREL="up"HREF="ch27_01.htm"TITLE="27. Searching Through Files"><LINKREL="prev"HREF="ch27_05.htm"TITLE="27.5 Extended Searching for Text with egrep "><LINKREL="next"HREF="ch27_07.htm"TITLE="27.7 grepping for a List of Patterns "></HEAD><BODYBGCOLOR="#FFFFFF"TEXT="#000000"><DIVCLASS="htmlnav"><H1><IMGSRC="gifs/smbanner.gif"ALT="UNIX Power Tools"USEMAP="#srchmap"BORDER="0"></H1><MAPNAME="srchmap"><AREASHAPE="RECT"COORDS="0,0,466,58"HREF="index.htm"ALT="UNIX Power Tools"><AREASHAPE="RECT"COORDS="467,0,514,18"HREF="jobjects/fsearch.htm"ALT="Search this book"></MAP><TABLEWIDTH="515"BORDER="0"CELLSPACING="0"CELLPADDING="0"><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="172"><ACLASS="SECT1"HREF="ch27_05.htm"TITLE="27.5 Extended Searching for Text with egrep "><IMGSRC="gifs/txtpreva.gif"SRC="gifs/txtpreva.gif"ALT="Previous: 27.5 Extended Searching for Text with egrep "BORDER="0"></A></TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="171"><B><FONTFACE="ARIEL,HELVETICA,HELV,SANSERIF"SIZE="-1">Chapter 27<BR>Searching Through Files</FONT></B></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="172"><ACLASS="SECT1"HREF="ch27_07.htm"TITLE="27.7 grepping for a List of Patterns "><IMGSRC="gifs/txtnexta.gif"SRC="gifs/txtnexta.gif"ALT="Next: 27.7 grepping for a List of Patterns "BORDER="0"></A></TD></TR></TABLE> <HRALIGN="LEFT"WIDTH="515"TITLE="footer"></DIV><DIVCLASS="SECT1"><H2CLASS="sect1"><ACLASS="title"NAME="UPT-ART-7954">27.6 Fast grep Isn't </A></H2><PCLASS="para"><ACLASS="indexterm"NAME="AUTOID-30130"></A><ACLASS="indexterm"NAME="AUTOID-30134"></A><ACLASS="indexterm"NAME="AUTOID-30137"></A>Have you heard this old saw:<BLOCKQUOTECLASS="blockquote"><PCLASS="para">UNIX beginners use <EMCLASS="emphasis">grep</EM> because it's all they know about.</P><PCLASS="para">Intermediate users use <EMCLASS="emphasis">fgrep</EM> because the manual says it'sfaster.</P><PCLASS="para">Advanced users use <EMCLASS="emphasis">egrep</EM> because they've tried it.</P></BLOCKQUOTE></P><PCLASS="para">Yes, despite what the manual page says (or rather, used to say, becausenowadays, many <EMCLASS="emphasis">grep</EM> manual pages have been rewritten toacknowledge the fact), <EMCLASS="emphasis">fgrep</EM> is usually the slowest of thethree standard <EMCLASS="emphasis">grep</EM>s. [I believe that <EMCLASS="emphasis">fgrep</EM> stands for "fixed <EMCLASS="emphasis">grep</EM>"because it doesn't accept metacharacters. <EMCLASS="emphasis">-JP</EM>]</P><PCLASS="para">If you want to prove this to yourself, try using the <EMCLASS="emphasis">runtime</EM> program (shown in article<ACLASS="xref"HREF="ch39_04.htm"TITLE="Average Command Runtimes with runtime ">39.4</A>)to give you the average execution time of a search.Here's the result of mysearch for the string <EMCLASS="emphasis">Waldo</EM> in a large directory crowded withsaved mail files.</P><PCLASS="para"><BLOCKQUOTECLASS="screen"><PRECLASS="screen">% <CODECLASS="userinput"><B>runtime -10 grep Waldo *</B></CODE> ...AVERAGES: 4.13u 0.83s 0:04 0+203k 21+0io 19pf+0w % <CODECLASS="userinput"><B>runtime -10 fgrep Waldo *</B></CODE> ...AVERAGES: 5.19u 0.80s 0:05 0+195k 4+0io 2pf+0w % <CODECLASS="userinput"><B>runtime -10 egrep Waldo *</B></CODE> ...AVERAGES: 2.61u 0.76s 0:02 0+244k 0+0io 0pf+0w</PRE></BLOCKQUOTE></P><PCLASS="para">On my SPARCstation IPC, <EMCLASS="emphasis">grep</EM> managed the search in four seconds,<EMCLASS="emphasis">fgrep</EM> in five, and <EMCLASS="emphasis">egrep</EM> in only two. <EMCLASS="emphasis">egrep</EM> also usedthe least CPU time.</P><PCLASS="para">Just for the heck of it, let's see how some other search programsstack up. <EMCLASS="emphasis">sed</EM>, <EMCLASS="emphasis">awk</EM>, and <EMCLASS="emphasis">perl</EM> can also emulate theaction of <EMCLASS="emphasis">grep</EM>:</P><PCLASS="para"><BLOCKQUOTECLASS="screen"><PRECLASS="screen">% <CODECLASS="userinput"><B>runtime -10 sed -n '/Waldo/p' *</B></CODE> ...AVERAGES: 3.64u 1.20s 0:04 0+227k 2+0io 1pf+0w % <CODECLASS="userinput"><B>runtime -10 awk '/Waldo/' *</B></CODE> ...AVERAGES: 4.86u 0.76s 0:05 0+279k 1+0io 0pf+0w % <CODECLASS="userinput"><B>runtime -10 perl -ne \'print if \(/Waldo/\) \; \' *</B></CODE> ...AVERAGES: 2.94u 0.69s 0:03 0+498k 28+4io 27pf+0w</PRE></BLOCKQUOTE></P><PCLASS="para">(Note that we have to escape any characters that the shell mightinterpret in the <EMCLASS="emphasis">perl</EM> command line.)</P><PCLASS="para"><EMCLASS="emphasis">perl</EM> is faster than all but <EMCLASS="emphasis">egrep</EM>, but even <EMCLASS="emphasis">sed</EM>edges your basic <EMCLASS="emphasis">grep</EM> by a hair.And <EMCLASS="emphasis">fgrep</EM> is by far the slowest - it even lost to <EMCLASS="emphasis">awk</EM>!</P><TABLECLASS="para.programreference"BORDER="1"><TR><THVALIGN="TOP"><ACLASS="programreference"HREF="examples/index.htm"TITLE="fgrep">fgrep</A><BR></TH><TDVALIGN="TOP"> This doesn't mean that <EMCLASS="emphasis">fgrep</EM> is useless, though.It has acouple of handy options:<EMCLASS="emphasis">-x</EM> requires a line to be exactly the same as the search pattern;<SPANCLASS="link"><EMCLASS="emphasis">-f</EM> (<ACLASS="linkend"HREF="ch27_07.htm"TITLE="grepping for a List of Patterns ">27.7</A>)</SPAN>takes one or many search patterns from a file.You can sometimes exploit the fact that <EMCLASS="emphasis">fgrep</EM> doesn't understandregular expressions, and so using it to search for literal asterisksor other regular expression metacharacters can save you a bit ofquoting.The time saved on the command line can be worth the slowerexecution speed.</TD></TR></TABLE><DIVCLASS="sect1info"><PCLASS="SECT1INFO">- <SPANCLASS="authorinitials">TOR</SPAN></P></DIV></DIV><DIVCLASS="htmlnav"><P></P><HRALIGN="LEFT"WIDTH="515"TITLE="footer"><TABLEWIDTH="515"BORDER="0"CELLSPACING="0"CELLPADDING="0"><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="172"><ACLASS="SECT1"HREF="ch27_05.htm"TITLE="27.5 Extended Searching for Text with egrep "><IMGSRC="gifs/txtpreva.gif"SRC="gifs/txtpreva.gif"ALT="Previous: 27.5 Extended Searching for Text with egrep "BORDER="0"></A></TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="171"><ACLASS="book"HREF="index.htm"TITLE="UNIX Power Tools"><IMGSRC="gifs/txthome.gif"SRC="gifs/txthome.gif"ALT="UNIX Power Tools"BORDER="0"></A></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="172"><ACLASS="SECT1"HREF="ch27_07.htm"TITLE="27.7 grepping for a List of Patterns "><IMGSRC="gifs/txtnexta.gif"SRC="gifs/txtnexta.gif"ALT="Next: 27.7 grepping for a List of Patterns "BORDER="0"></A></TD></TR><TR><TDALIGN="LEFT"VALIGN="TOP"WIDTH="172">27.5 Extended Searching for Text with egrep </TD><TDALIGN="CENTER"VALIGN="TOP"WIDTH="171"><ACLASS="index"HREF="index/idx_0.htm"TITLE="Book Index"><IMGSRC="gifs/index.gif"SRC="gifs/index.gif"ALT="Book Index"BORDER="0"></A></TD><TDALIGN="RIGHT"VALIGN="TOP"WIDTH="172">27.7 grepping for a List of Patterns </TD></TR></TABLE><HRALIGN="LEFT"WIDTH="515"TITLE="footer"><IMGSRC="gifs/smnavbar.gif"SRC="gifs/smnavbar.gif"USEMAP="#map"BORDER="0"ALT="The UNIX CD Bookshelf Navigation"><MAPNAME="map"><AREASHAPE="RECT"COORDS="0,0,73,21"HREF="../index.htm"ALT="The UNIX CD Bookshelf"><AREASHAPE="RECT"COORDS="74,0,163,21"HREF="index.htm"ALT="UNIX Power Tools"><AREASHAPE="RECT"COORDS="164,0,257,21"HREF="../unixnut/index.htm"ALT="UNIX in a Nutshell"><AREASHAPE="RECT"COORDS="258,0,321,21"HREF="../vi/index.htm"ALT="Learning the vi Editor"><AREASHAPE="RECT"COORDS="322,0,378,21"HREF="../sedawk/index.htm"ALT="sed & awk"><AREASHAPE="RECT"COORDS="379,0,438,21"HREF="../ksh/index.htm"ALT="Learning the Korn Shell"><AREASHAPE="RECT"COORDS="439,0,514,21"HREF="../lrnunix/index.htm"ALT="Learning the UNIX Operating System"></MAP></DIV></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -