date comparison in bash


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting date comparison in bash
# 1  
Old 07-16-2009
date comparison in bash

Hi

I have this simple script:

#!/bin/bash
date1=2009:07:15:12:36
date2=2009:07:15:12:16

echo $date1
echo $date2

datediff=
#datediff=date1-date2
echo datediff is$datediff

How do i return the difference in seconds?
# 2  
Old 07-16-2009
you seem to have missed 1 field
the correct format should be
Code:
YYYY:MM:DD:HH:mm:ss

or you wanted this only?

---------- Post updated at 03:36 PM ---------- Previous update was at 03:05 PM ----------

Try:
Since you wanted the diff in sec, I have left it in sec.
for the condition when the years are diff, you will have to add the condition.
Code:
#!/bin/bash

timeCalc()
{
   (( _diff = ($1*3600+$2*60+$3) - ($4*3600+$5*60+$6) ))
   return ${_diff}
}

date1=2009:07:15:12:36
date2=2009:07:15:12:16

echo $date1
echo $date2

_date1=$(echo $date1|awk -F":" '{print $1" "$2" "$3}')
_date2=$(echo $date2|awk -F":" '{print $1" "$2" "$3}')
_time1=$(echo $date1|awk -F":" '{$6==""?$6=0:$6=$6;print $4" "$5" "$6}')
_time2=$(echo $date2|awk -F":" '{$6==""?$6=0:$6=$6;print $4" "$5" "$6}')

dateDiff=$(datecalc -a ${_date1} - ${_date2})

if [[ $dateDiff -eq 0 ]]; then
   timeCalc ${_time1} ${_time2}
fi
echo Diff in second is ${_diff} sec.

PS: datecalc you will have to get from unix.com
# 3  
Old 07-16-2009
Looks good. Where do i find this datecalc method?
# 4  
Old 07-16-2009
# 5  
Old 07-16-2009
hmm this datecalc return an error bin/datecalc[204]: print: bad option(s)

I have not changed a thing?

---------- Post updated at 07:57 AM ---------- Previous update was at 07:54 AM ----------

I also need to know the diff in year, month and seconds. I think it only displays the diff time in seconds?
# 6  
Old 07-16-2009
It works for me... See if it is copied properly

---------- Post updated at 06:32 PM ---------- Previous update was at 06:31 PM ----------

Quote:
Originally Posted by carp.dk
hmm this datecalc return an error bin/datecalc[204]: print: bad option(s)

I have not changed a thing?

---------- Post updated at 07:57 AM ---------- Previous update was at 07:54 AM ----------

I also need to know the diff in year, month and seconds. I think it only displays the diff time in seconds?
I wrote that in my comment, Smilie You can print that with year, month diff getting from datecalc
# 7  
Old 07-17-2009
I got it to work as well. Thanks!
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

awk IF date comparison help

Hey everyone, I'm trying to create a script using awk and if that will list all of our aws tapes that have archived date that is past 90 days from todays current date, so that I can pass that to my aws command to remove. The fifth column is the creation date in epoch/seconds, so I'm... (13 Replies)
Discussion started by: beyondmondays
13 Replies

2. UNIX for Dummies Questions & Answers

Date comparison

I have below txt file 02.05.2014 10.05.2014 17.09.2014 My requirement is the user enter date field should compare the input file if user enter date as 12.03.2013 it should compare with all date one by one from input file 12.03.2013 -ne 02.05.2014 12.03.2013 -ne 10.05.2014... (3 Replies)
Discussion started by: stew
3 Replies

3. Shell Programming and Scripting

Date Comparison

Hi Need some function or step to compare the date as given below. Example: Date_1: 25/04/2013 Date_2: 20/07/2012 if Date_1 is greater than Date_2 then do... else do.. fi Need exact unix steps to compare the above condition Use code tags please, see PM. (5 Replies)
Discussion started by: anshaa
5 Replies

4. Shell Programming and Scripting

Date comparison script

hi, I have a file named user.cfg under /var/member/ #user.cfg file under /var/member/ login user: root #how are you login pass: admin #where are you M: user1 pass1 #20121008 M: user2 pass2 #20111230 M: user3 pass3 #20091220 M: user4 pass4 #20070210 M: user5 pass5 #20130708 M:... (3 Replies)
Discussion started by: baris35
3 Replies

5. UNIX for Dummies Questions & Answers

date comparison

Hi friends, I would like to compare two dates in an IF statement. This is what I am trying, but it doesn't work. date=20120122 minus=6 if ; then ... fi what would the IF clause looks like? Thanks! :) (5 Replies)
Discussion started by: kokoro
5 Replies

6. Solaris

Date comparison

Date comparison Hello all I am writing a scrip that will take action so long as the date with in the file is older than 3 months. The file will contain multiple rows of data. Each row will probably start with the date. My question... What is the exact code that should be used for date... (1 Reply)
Discussion started by: UofU
1 Replies

7. Shell Programming and Scripting

Date comparison using ksh

Hi All, i have a text sample below. rootdbs 1 0 01/03/2010.03:11 physdbs 2 0 01/03/2010.03:17 logdbs01 3 0 01/03/2010.03:17 logdbs02 4 0 01/03/2010.03:17 dbs01 5 0 01/03/2010.03:17 dbs02 6 0 01/03/2010.03:17 dbs03 7 0 01/03/2010.03:17 dbs04 ... (4 Replies)
Discussion started by: informix2009
4 Replies

8. Homework & Coursework Questions

Date comparison with 'string date having slashes and time zone' in Bash only

1. The problem statement, all variables and given/known data: I have standard web server log file. It contains different columns (like IP address, request result code, request type etc) including a date column with the format . I have developed a log analysis command line utility that displays... (1 Reply)
Discussion started by: TariqYousaf
1 Replies

9. Shell Programming and Scripting

Date comparison

Hi all, I've a shell script which runs on Bourne shell. I've to do a date comparison. If the value of the supplied parameter(in format YYYYMMDD)is greater than todays's date(format YYYYMMDD), it should prompt the user that the supplied date is greater than today's date. The script is given... (6 Replies)
Discussion started by: sumesh.abraham
6 Replies

10. Shell Programming and Scripting

date comparison

How can I compare two dates in String format (eg. May 23 2006 05:30:21) in AWK? Thanks (2 Replies)
Discussion started by: dkr123
2 Replies
Login or Register to Ask a Question