?? logreader.html
字號:
<a name="588" href="#588">588</a> <em>/**<em>*</em></em><a name="589" href="#589">589</a> <em> * Returns all lines in a log/file matching a given regular expression. </em><a name="590" href="#590">590</a> <em> * Possible to get lines immediately following the matched line. Also </em><a name="591" href="#591">591</a> <em> * possible to have each line prepended by it's line number.</em><a name="592" href="#592">592</a> <em> *</em><a name="593" href="#593">593</a> <em> * @param aFileName The filename of the log/file</em><a name="594" href="#594">594</a> <em> * @param regExpr The regular expression that is to be used</em><a name="595" href="#595">595</a> <em> * @param addLines Any lines following a match that <b>begin</b> with this </em><a name="596" href="#596">596</a> <em> * string will also be included. We will stop including new </em><a name="597" href="#597">597</a> <em> * lines once we hit the first that does not match.</em><a name="598" href="#598">598</a> <em> * @param prependLineNumbers If true, then each line will be prepended by </em><a name="599" href="#599">599</a> <em> * it's line number in the file.</em><a name="600" href="#600">600</a> <em> * @param skipFirstMatches The first number of matches up to this value will</em><a name="601" href="#601">601</a> <em> * be skipped over.</em><a name="602" href="#602">602</a> <em> * @param numberOfMatches Once past matches that are to be skipped this many</em><a name="603" href="#603">603</a> <em> * matches will be added to the return value. A</em><a name="604" href="#604">604</a> <em> * value of 0 will cause all matching lines to be</em><a name="605" href="#605">605</a> <em> * included.</em><a name="606" href="#606">606</a> <em> * @return An array of two strings is returned. At index 0 tall lines in a</em><a name="607" href="#607">607</a> <em> * log/file matching a given regular expression is located.</em><a name="608" href="#608">608</a> <em> * At index 1 there is an informational string about how large a</em><a name="609" href="#609">609</a> <em> * segment of the file is being returned.</em><a name="610" href="#610">610</a> <em> * Null is returned if errors occur (file not found or io exception)</em><a name="611" href="#611">611</a> <em> * If a PatternSyntaxException occurs, it's error message will be</em><a name="612" href="#612">612</a> <em> * returned and the informational string will be empty (not null).</em><a name="613" href="#613">613</a> <em> */</em><a name="614" href="#614">614</a> <strong>public</strong> <strong>static</strong> String[] getByRegExprFromSeries(String aFileName, <a name="615" href="#615">615</a> String regExpr, <a name="616" href="#616">616</a> String addLines, <a name="617" href="#617">617</a> <strong>boolean</strong> prependLineNumbers,<a name="618" href="#618">618</a> <strong>int</strong> skipFirstMatches,<a name="619" href="#619">619</a> <strong>int</strong> numberOfMatches){<a name="620" href="#620">620</a> <strong>try</strong> {<a name="621" href="#621">621</a> File f = <strong>new</strong> File(aFileName);<a name="622" href="#622">622</a> <strong>return</strong> getByRegExpr(<a name="623" href="#623">623</a> seriesReader(aFileName),<a name="624" href="#624">624</a> regExpr,<a name="625" href="#625">625</a> addLines,<a name="626" href="#626">626</a> prependLineNumbers,<a name="627" href="#627">627</a> skipFirstMatches,<a name="628" href="#628">628</a> numberOfMatches,<a name="629" href="#629">629</a> f.length());<a name="630" href="#630">630</a> } <strong>catch</strong> (IOException e) {<a name="631" href="#631">631</a> e.printStackTrace();<a name="632" href="#632">632</a> <strong>return</strong> <strong>null</strong>;<a name="633" href="#633">633</a> }<a name="634" href="#634">634</a> }<a name="635" href="#635">635</a> <a name="636" href="#636">636</a> <em>/**<em>*</em></em><a name="637" href="#637">637</a> <em> * Returns all lines in a log/file matching a given regular expression. </em><a name="638" href="#638">638</a> <em> * Possible to get lines immediately following the matched line. Also </em><a name="639" href="#639">639</a> <em> * possible to have each line prepended by it's line number.</em><a name="640" href="#640">640</a> <em> *</em><a name="641" href="#641">641</a> <em> * @param reader The reader of the log/file</em><a name="642" href="#642">642</a> <em> * @param regExpr The regular expression that is to be used</em><a name="643" href="#643">643</a> <em> * @param addLines Any lines following a match that <b>begin</b> with this </em><a name="644" href="#644">644</a> <em> * string will also be included. We will stop including new </em><a name="645" href="#645">645</a> <em> * lines once we hit the first that does not match.</em><a name="646" href="#646">646</a> <em> * @param prependLineNumbers If true, then each line will be prepended by </em><a name="647" href="#647">647</a> <em> * it's line number in the file.</em><a name="648" href="#648">648</a> <em> * @param skipFirstMatches The first number of matches up to this value will</em><a name="649" href="#649">649</a> <em> * be skipped over.</em><a name="650" href="#650">650</a> <em> * @param numberOfMatches Once past matches that are to be skipped this many</em><a name="651" href="#651">651</a> <em> * matches will be added to the return value. A</em><a name="652" href="#652">652</a> <em> * value of 0 will cause all matching lines to be</em><a name="653" href="#653">653</a> <em> * included.</em><a name="654" href="#654">654</a> <em> * @param logsize Size of the log in bytes</em><a name="655" href="#655">655</a> <em> * @return An array of two strings is returned. At index 0 tall lines in a</em><a name="656" href="#656">656</a> <em> * log/file matching a given regular expression is located.</em><a name="657" href="#657">657</a> <em> * At index 1 there is an informational string about how large a</em><a name="658" href="#658">658</a> <em> * segment of the file is being returned.</em><a name="659" href="#659">659</a> <em> * Null is returned if errors occur (file not found or io exception)</em><a name="660" href="#660">660</a> <em> * If a PatternSyntaxException occurs, it's error message will be</em><a name="661" href="#661">661</a> <em> * returned and the informational string will be empty (not null).</em><a name="662" href="#662">662</a> <em> */</em><a name="663" href="#663">663</a> <strong>public</strong> <strong>static</strong> String[] getByRegExpr(InputStreamReader reader, <a name="664" href="#664">664</a> String regExpr, <a name="665" href="#665">665</a> String addLines, <a name="666" href="#666">666</a> <strong>boolean</strong> prependLineNumbers,<a name="667" href="#667">667</a> <strong>int</strong> skipFirstMatches,<a name="668" href="#668">668</a> <strong>int</strong> numberOfMatches,<a name="669" href="#669">669</a> <strong>long</strong> logsize) {<a name="670" href="#670">670</a> StringBuffer ret = <strong>new</strong> StringBuffer();<a name="671" href="#671">671</a> String info = <span class="string">""</span>;<a name="672" href="#672">672</a> <strong>try</strong>{<a name="673" href="#673">673</a> Matcher m = Pattern.compile(regExpr).matcher(<span class="string">""</span>);<a name="674" href="#674">674</a> BufferedReader bf = <strong>new</strong> BufferedReader(reader, 8192);<a name="675" href="#675">675</a> <a name="676" href="#676">676</a> String line = <strong>null</strong>;<a name="677" href="#677">677</a> <strong>int</strong> i = 1;<a name="678" href="#678">678</a> <strong>boolean</strong> doAdd = false;<a name="679" href="#679">679</a> <strong>long</strong> linesMatched = 0;<a name="680" href="#680">680</a> <strong>while</strong> ((line = bf.readLine()) != <strong>null</strong>) {<a name="681" href="#681">681</a> m.reset(line);<a name="682" href="#682">682</a> <strong>if</strong>(m.matches()){<a name="683" href="#683">683</a> <em class="comment">// Found a match</em><a name="684" href="#684">684</a> <strong>if</strong>(numberOfMatches > 0 && <a name="685" href="#685">685</a> linesMatched >= skipFirstMatches + numberOfMatches){<a name="686" href="#686">686</a> <em class="comment">// Ok, we are done.</em><a name="687" href="#687">687</a> <strong>break</strong>;<a name="688" href="#688">688</a> }<a name="689" href="#689">689</a> linesMatched++;<a name="690" href="#690">690</a> <strong>if</strong>(linesMatched > skipFirstMatches){<a name="691" href="#691">691</a> <strong>if</strong>(prependLineNumbers){<a name="692" href="#692">692</a> ret.append(i);<a name="693" href="#693">693</a> ret.append(<span class="string">". "</span>);<a name="694" href="#694">694</a> }<a name="695" href="#695">695</a> ret.append(line);<a name="696" href="#696">696</a> ret.append(<span class="string">"\n"</span>);<a name="697" href="#697">697</a> doAdd = <strong>true</strong>;<a name="698" href="#698">698</a> }<a name="699" href="#699">699</a> } <strong>else</strong> <strong>if</strong>(doAdd) {<a name="700" href="#700">700</a> <strong>if</strong>(line.indexOf(addLines)==0){<a name="701" href="#701">701</a> linesMatched++;<a name="702" href="#702">702</a> <em class="comment">//Ok, line begins with 'addLines'</em><a name="703" href="#703">703</a> <strong>if</strong>(prependLineNumbers){<a name="704" href="#704">704</a> ret.append(i);<a name="705" href="#705">705</a> ret.append(<span class="string">". "</span>);<a name="706" href="#706">706</a> }<a name="707" href="#707">707</a> ret.append(line);<a name="708" href="#708">708</a> ret.append(<span class="string">"\n"</span>);<a name="709" href="#709">709</a> }<strong>else</strong>{<a name="710" href="#710">710</a> doAdd = false;<a name="711" href="#711">711</a> }<a name="712" href="#712">712</a> }<a name="713" href="#713">713</a> i++;<a name="714" href="#714">714</a> }<a name="715" href="#715">715</a> info = buildDisplayingHeader(ret.length(), logsize);<a name="716" href="#716">716</a> }<strong>catch</strong>(FileNotFoundException e){<a name="717" href="#717">717</a> <strong>return</strong> <strong>null</strong>;<a name="718" href="#718">718</a> }<strong>catch</strong>(IOException e){<a name="719" href="#719">719</a> e.printStackTrace();<a name="720" href="#720">720</a> <strong>return</strong> <strong>null</strong>;<a name="721" href="#721">721</a> }<strong>catch</strong>(PatternSyntaxException e){<a name="722" href="#722">722</a> ret = <strong>new</strong> StringBuffer(e.getMessage());<a name="723" href="#723">723</a> }<a name="724" href="#724">724</a> String[] tmp = {ret.toString(),info};<a name="725" href="#725">725</a> <strong>return</strong> tmp;<a name="726" href="#726">726</a> }<a name="727" href="#727">727</a> <a name="728" href="#728">728</a> <em>/**<em>*</em></em><a name="729" href="#729">729</a> <em> * Implementation of a unix-like 'tail' command</em><a name="730" href="#730">730</a> <em> *</em><a name="731" href="#731">731</a> <em> * @param aFileName a file name String</em><a name="732" href="#732">732</a> <em> * @return An array of two strings is returned. At index 0 the String</em><a name="73
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -