Beefy Boxes and Bandwidth Generously Provided by pair Networks
Think about Loose Coupling
 
PerlMonks  

Re: counting yesterdays hits in a logfile

by space_monk (Chaplain)
on Nov 13, 2012 at 05:10 UTC ( #1003552=note: print w/ replies, xml ) Need Help??


in reply to counting yesterdays hits in a logfile

I'm assuming you only need to count the number of hits as you say, not list them as you have done in your example. First you need the string for yesterdays date. This is one way but there are others....

use POSIX qw(strftime); $time= localtime(time-(24*60*60)); $yesterday = strftime( '%d/%m/%y', $time);
There are other and better ways using libraries such as Date::Calc to do the same thing.
`grep "$yesterday" logfile.log | wc -l`

Number of lines returned is the number of hits on your site. This command can be run inside a Perl script inside backticks.

However, the grep command exists in Perl too, so just read the file into an array and use the Perl grep command, as in scalar context it returns the number of matches.

open(LOGFILE,"<", "access.log")or die"Could not open log file."; my @logfile = <LOGFILE> my $hits = grep /$yesterday/, @logfile;
A Monk aims to give answers to those who have none, and to learn from those who know more.


Comment on Re: counting yesterdays hits in a logfile
Select or Download Code

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://1003552]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others drinking their drinks and smoking their pipes about the Monastery: (12)
As of 2014-07-28 12:32 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    My favorite superfluous repetitious redundant duplicative phrase is:









    Results (196 votes), past polls