Difference between two date


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Difference between two date
# 1  
Old 05-02-2015
Difference between two date

Hi,
I created a script for finding the duration of a job using the start and end time of the job. But the command doesnt calculate correct value if the duration is more than 24 hours. Any help would be really good

.
Code:
cat test1    --- start time
03/27/15 17:41:00
03/24/15 11:58:04
03/23/15 06:00:00

cat test2    --- end time
03/27/15 17:51:30
03/24/15 18:14:01
03/24/15 07:00:00

Calculating difference using the below command
let DIFF=(`date +%s -d "$b"` - `date +%s -d "$a"`)   // calculating the duration in seconds
echo|date -u -d @${DIFF} +"%H"h" %M"m""  // converting into H:M format.

output

00h 10m   -- correct value
06h 15m   --  correct value
01h 00m   -- In correct value . Instead of 25h printing 1h as its not deducting the day from 24 to 23.

rogerben
# 2  
Old 05-02-2015
date is giving an hour and minute for a timestamp. you'll need to calculate hours and minutes yourself.

Code:
mute@tiny:~$ a='03/23/15 06:00:00' b='03/24/15 07:00:00' diff=$(( $(date +%s -d "$b") - $(date +%s -d "$a") ))
mute@tiny:~$ printf '%dh %02dm\n' $((diff=diff/3600)) $((diff/60))
25h 00m

This User Gave Thanks to neutronscott For This Post:
# 3  
Old 05-04-2015
Hi,
Thanks for your reply. The command is working fine for hours but it is not converting into minutes.

Used the below command and it works fine. Thanks a lot
printf '%dh %02dm\n' $((DIFF/3600)) $((DIFF%3600/60))

Last edited by rogerben; 05-04-2015 at 02:03 AM.. Reason: Found solution.
rogerben
# 4  
Old 05-04-2015
Try this instead:

Code:
$ printf '%dh %02dm\n' $((diff/3600)) $(((diff%3600)/60))

This User Gave Thanks to Chubler_XL For This Post:
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. AIX

Time Difference between date and date -u

Hi Everyone, We are having an issue with date and date -u in our AIX Systems. We have checked environment variable TZ and /etc/environment and however, we could not rectify the difference. >date Thu Mar 19 22:31:40 IST 2015 >date -u Thu Mar 19 17:01:44 GMT 2015 Any clue... (5 Replies)
Discussion started by: madhav.kunapa
5 Replies

2. Shell Programming and Scripting

Date difference

HI All , i need a bash script to find the number of days between two dates . Format YYYY-MM-DD THanks, Neil (1 Reply)
Discussion started by: nevil
1 Replies

3. Programming

Date difference

I tried the below code to find difference between two dates. It works fine if the day of the month is 2-digit number. But it fails when we have a single-digit day of month(ex:1-9). my code is as below. please help me soon. #!/usr/bin/perl -w use strict; use Time::Local; ... (2 Replies)
Discussion started by: anandrec
2 Replies

4. Homework & Coursework Questions

help with the date difference

1. The problem statement, all variables and given/known data: The problem i have is that i probably make a few mistake here in the code but don't know what it is and i try to get the date difference but don't know where to add the days_in_month function 2. Relevant commands, code,... (1 Reply)
Discussion started by: mgyeah
1 Replies

5. Shell Programming and Scripting

Difference in date

Dear all, I fancy that I'm pretty competent in ksh, but I have someone on HP-UX wanting me to script up a simple interface to handle user alterations rather than giving them high privileges to run up SAM. This is all fairly straightforward, but I'm stuck on an epoch date issue. When we have... (6 Replies)
Discussion started by: rbatte1
6 Replies

6. Shell Programming and Scripting

difference in date

Hi All! I would like to know the time difference between two dates which are in same format... $ date -r abc Thu Oct 29 09:40:37 EDT 2009 $ date Fri Oct 30 02:07:03 EDT 2009 i would like to find the diff between these two dates in hours..please help..:) Regards, Kiran (3 Replies)
Discussion started by: dddkiran
3 Replies

7. Linux

date difference

hi, i have 2 dates in the form: '20080315120030' and '20080310140030'. i.e. YYYYMMDDHHMMSS. i need a way of getting the difference between them using shell script. any thoughts? (14 Replies)
Discussion started by: muay_tb
14 Replies

8. Shell Programming and Scripting

date difference

if there are two date one is entered by user and another is system date than how can we finds day difference between these two date try to make it within 4 lines (2 Replies)
Discussion started by: piyush_movadiya
2 Replies

9. UNIX for Dummies Questions & Answers

date difference

Hi Can any buddy give mi a simple program or logic or command which will get difference between two dates ex:diff between 20051008 2005908 is 24hours 12 min 2 sec regards (1 Reply)
Discussion started by: rajuMBT
1 Replies

10. UNIX for Advanced & Expert Users

date difference

Hi...I need some help with a date script. I need to allow the user to enter the month (alpha) day (int) and year (YYYY) and count the difference in number of days since Jan 1, 1952 to the users date. I've been messing with this for about 10 hours and I think I'm just making the script worse =( ... (1 Reply)
Discussion started by: mtnbaby
1 Replies
Login or Register to Ask a Question