date difference


 
Thread Tools Search this Thread
Operating Systems Linux date difference
# 1  
Old 03-17-2008
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?
# 2  
Old 03-17-2008
note i only have the following date utility:

usage: date [-u] mmddHHMM[[cc]yy][.SS]
date [-u] [+format]
date -a [-]sss[.fff]
# 3  
Old 03-17-2008
at present i have this:

for file in `find ${my_dir}/ -name "*_statsfile_??????????????.gz" -print`
do
ONEDAY=86400
NOW=$(date -u +%Y%m%d%H%M%S)

FILEDATE=`echo $file | sed -e 's/^.*_stats_//g' -e 's/\.gz$//g'`

((DIFF=$NOW - $FILEDATE))
CALC_DIFF=$(($DIFF / $ONEDAY))

echo "[$file], Current Time: $NOW. File Time: $FILEDATE. Difference: $CALC_DIFF."
done


both dates need to be in UTC. Is there a way to make them BOTH UTC. the date 'NOW' is UTC but the 'FILEDATE' isnt. Smilie
# 4  
Old 03-17-2008
It's possible but it would help if you could say which time zone the second one is.

The standard solution would be to convert them both to a canonical format (maybe epoch, that is, seconds since Jan 1 1970) and then the problem is just how to format the result back as a human-readable time expression. In what form would you like the output?

I would use Perl or Python because they come with handy libraries which can do the grunt work for you.
era
# 5  
Old 03-17-2008
Quote:
Originally Posted by era
It's possible but it would help if you could say which time zone the second one is.

The standard solution would be to convert them both to a canonical format (maybe epoch, that is, seconds since Jan 1 1970) and then the problem is just how to format the result back as a human-readable time expression. In what form would you like the output?

I would use Perl or Python because they come with handy libraries which can do the grunt work for you.
at the moment the first date, NOW is using date -u (UTC) and the file names will also be UTC. At present i have created dummy files with made up time stamps.

i basically want to delete files over 3 days old in a directory using the current date as a marker...i cant use -mtime as a person may modify the file and the modified time will not be the same as the filename. So therefore i am using the filename as the second time stamp. if you follow me?

im only after the number of days between the 2 dates.

Last edited by muay_tb; 03-17-2008 at 01:25 PM..
# 6  
Old 03-17-2008
If you have control over the file names then simply compare the date stamp in the file's name with the output of
Code:
date -d "3 days ago" -u +%Y%m%d%H%M%S

era
# 7  
Old 03-17-2008
Quote:
Originally Posted by era
If you have control over the file names then simply compare the date stamp in the file's name with the output of
Code:
date -d "3 days ago" -u +%Y%m%d%H%M%S

thats where the problem is, i get the following error:

date: illegal option -- d
usage: date [-u] mmddHHMM[[cc]yy][.SS]
date [-u] [+format]
date -a [-]sss[.fff]
Smilie
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

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 . cat test1 --- start time 03/27/15 17:41:00 03/24/15 11:58:04 03/23/15... (3 Replies)
Discussion started by: rogerben
3 Replies

2. 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

3. 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

4. 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

5. 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

6. 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

7. 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

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