?
Solved

date question

Posted on 2000-03-27
2
Medium Priority
?
184 Views
Last Modified: 2006-11-17

I need to write an if/else statement with the if being:

If current date is after the second sunday of march and before the second wednesday of june.......

I know how to do the basic if/else statement, but don't know how to write this 'if', could someone give me an example?

It needs to work annually, so year will not be included.

Thanks,

Chris
0
Comment
Question by:ChrisAndrews
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 1

Expert Comment

by:mafweb
ID: 2663039
try the following: the time() function returns the seconds since 1970-01-01
then, you check the days from the eighth of march to the fourteenth of march of the year interesting you (current year?) by first calculating their time (in secs) and then using the date("l", $time) function to  see whether it a "sunday" When you've  found the sunday, store its value, so the same for the interval in june, and then do
if (time()>$start && time()>$end) ...

hope this helps
maf
0
 

Accepted Solution

by:
brad_fuller earned 200 total points
ID: 2663640
This script  uses date math functions to work out  this info

I orginally wrote it to send remnders on the second and 4th
mondays of the month - so it's a bit of a hack :^)

I tried to tidy it up for you, but I think you'll get the idea... hope the text isn't wrapped by this form ...

<?

function GetTargetDate($monthnumber,$target_day,$target_day_occurrence) {
// where:
//      $monthnumber=1 to 12 ; // march=3
//       $target_day=0-6 ; // 0=sunday, 1=monday ...
//       $target_day_occurrence - which day in the month (eg 2nd / 3rd monday )

$oneday=86400 ; //seconds
$now=time();
$thisyear=date("Y",$now);

$firstofmonth=mktime(0,0,0,$monthnumber,1,$thisyear);
$lastofmonth=mktime(0,0,0,$monthnumber+1,1,$thisyear); // first day of next month
$lastofmonth=$lastofmonth-$oneday; // the day before (I love date math :^)

$testday=$firstofmonth; // start from day one
// find first "$target_day" in this month (Sunday is daynumber 0)
do {
      $daynumber=date("w",$testday);
      $testday += $oneday; // next day
} while ($daynumber!=$target_day);

$target_date=$testday-$oneday; // doh - we just went one day over of course.

$target_date=$target_date + (($oneday * 7) * ($target_day_occurrence-1)) ;

return $target_date;

}

// examples:
$startdate=GetTargetDate(3,0,2);
print "<P> 2nd sunday in march is " . date( "d - M - Y",$startdate) ;

$finishdate=GetTargetDate(6,3,2);
print "<P> 2nd wednesday in june is " . date("d -M -Y",$finishdate) ;

$todaysdate=date("d",$now);

if (($todaysdate <= $startdate) && ($todaysdate <= $finishdate) ) {
      // do whatever.
} //endif

?>
0

Featured Post

VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Foreword (July, 2015) Since I first wrote this article, years ago, a great many more people have begun using the internet.  They are coming online from every part of the globe, learning, reading, shopping and spending money at an ever-increasing ra…
Since pre-biblical times, humans have sought ways to keep secrets, and share the secrets selectively.  This article explores the ways PHP can be used to hide and encrypt information.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to create and use a small PHP class to apply a watermark to an image. This video shows the viewer the setup for the PHP watermark as well as important coding language. Continue to Part 2 to learn the core code used in creat…
Suggested Courses

765 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question