Wednesday, 24 September 2014
India scripts history, becomes the first country to send Mars Orbiter in first attempt
Cost - $71 million which is $29 million less than the cost of hollywood movie GRAVITY.
Is't it amazing?
Read more in
http://indianexpress.com/article/india/india-others/india-succeeds-putting-spacecraft-in-martian-orbit/
Wednesday, 3 September 2014
Java Program for calculating business days considering public holidays
This is in continuation to my previous post...
This is a Java Program for calculating business days considering public holidays
public long getNumberOfBusinessDays(Date start, Date end)
{
if (start == null || end == null)
return 0;
long daysWithoutSunday = 0;
int w1 = 0;
int w2 = 0;
long actualNumberOfBusinessDays = 0;
Calendar c1 = GregorianCalendar.getInstance();
c1.setTime(start);
w1 = c1.get(Calendar.DAY_OF_WEEK);
c1.add(Calendar.DAY_OF_WEEK, -w1 + 1);
Calendar c2 = GregorianCalendar.getInstance();
c2.setTime(end);
w2 = c2.get(Calendar.DAY_OF_WEEK);
c2.add(Calendar.DAY_OF_WEEK, -w2 + 1);
//end Saturday to start Saturday
long days = (c2.getTimeInMillis() - c1.getTimeInMillis())/(1000*60*60*24);
daysWithoutSunday = days-(days*2/7);
if (w1 == Calendar.SUNDAY)
w1 = Calendar.MONDAY;
if (w2 == Calendar.SUNDAY)
w2 = Calendar.MONDAY;
/*
* Check if the there are dates which are falling in public holidays?
* Currently handling only Christmas & New Year days.
*/
long numberOfBusinessDaysWithoutSundayAndSaturday = daysWithoutSunday - w1 + w2;
actualNumberOfBusinessDays = numberOfBusinessDaysWithoutSundayAndSaturday;
while (numberOfBusinessDaysWithoutSundayAndSaturday > 0 && start.before(end))
{
if (isPublicHoliday(start))
actualNumberOfBusinessDays -= 1;
start = addDay(start);
numberOfBusinessDaysWithoutSundayAndSaturday -= 1;
}
return actualNumberOfBusinessDays;
}
public static boolean isPublicHoliday(Date date)
{
Calendar cal = Calendar.getInstance();
cal.setTime(date);
int w1 = cal.get(Calendar.DAY_OF_WEEK);
// check if New Year's Day & not falls on a Saturday or Sunday because weekends are already taken care
if (cal.get(Calendar.MONTH) == Calendar.JANUARY && cal.get(Calendar.DAY_OF_MONTH) == 1 && w1 != Calendar.SUNDAY && w1 != Calendar.SATURDAY)
return true;
// check if Christmas & not falls on a Saturday or Sunday because weekends are already taken care
if (cal.get(Calendar.MONTH) == Calendar.DECEMBER && cal.get(Calendar.DAY_OF_MONTH) == 25 && w1 != Calendar.SUNDAY && w1 != Calendar.SATURDAY)
return true;
return false;
}
private static Date addDay(Date date)
{
Calendar cal = Calendar.getInstance();
cal.setTime (date);
cal.add (Calendar.DATE, 1);
return cal.getTime();
}
This is a Java Program for calculating business days considering public holidays
public long getNumberOfBusinessDays(Date start, Date end)
{
if (start == null || end == null)
return 0;
long daysWithoutSunday = 0;
int w1 = 0;
int w2 = 0;
long actualNumberOfBusinessDays = 0;
Calendar c1 = GregorianCalendar.getInstance();
c1.setTime(start);
w1 = c1.get(Calendar.DAY_OF_WEEK);
c1.add(Calendar.DAY_OF_WEEK, -w1 + 1);
Calendar c2 = GregorianCalendar.getInstance();
c2.setTime(end);
w2 = c2.get(Calendar.DAY_OF_WEEK);
c2.add(Calendar.DAY_OF_WEEK, -w2 + 1);
//end Saturday to start Saturday
long days = (c2.getTimeInMillis() - c1.getTimeInMillis())/(1000*60*60*24);
daysWithoutSunday = days-(days*2/7);
if (w1 == Calendar.SUNDAY)
w1 = Calendar.MONDAY;
if (w2 == Calendar.SUNDAY)
w2 = Calendar.MONDAY;
/*
* Check if the there are dates which are falling in public holidays?
* Currently handling only Christmas & New Year days.
*/
long numberOfBusinessDaysWithoutSundayAndSaturday = daysWithoutSunday - w1 + w2;
actualNumberOfBusinessDays = numberOfBusinessDaysWithoutSundayAndSaturday;
while (numberOfBusinessDaysWithoutSundayAndSaturday > 0 && start.before(end))
{
if (isPublicHoliday(start))
actualNumberOfBusinessDays -= 1;
start = addDay(start);
numberOfBusinessDaysWithoutSundayAndSaturday -= 1;
}
return actualNumberOfBusinessDays;
}
public static boolean isPublicHoliday(Date date)
{
Calendar cal = Calendar.getInstance();
cal.setTime(date);
int w1 = cal.get(Calendar.DAY_OF_WEEK);
// check if New Year's Day & not falls on a Saturday or Sunday because weekends are already taken care
if (cal.get(Calendar.MONTH) == Calendar.JANUARY && cal.get(Calendar.DAY_OF_MONTH) == 1 && w1 != Calendar.SUNDAY && w1 != Calendar.SATURDAY)
return true;
// check if Christmas & not falls on a Saturday or Sunday because weekends are already taken care
if (cal.get(Calendar.MONTH) == Calendar.DECEMBER && cal.get(Calendar.DAY_OF_MONTH) == 25 && w1 != Calendar.SUNDAY && w1 != Calendar.SATURDAY)
return true;
return false;
}
private static Date addDay(Date date)
{
Calendar cal = Calendar.getInstance();
cal.setTime (date);
cal.add (Calendar.DATE, 1);
return cal.getTime();
}
Java program to calculate the number of business days between two dates.
This is a Java program to calculate the number of business days between two dates..
This program will exclude only Saturdays & Sundays and not the public holidays.
This program will exclude only Saturdays & Sundays and not the public holidays.
public long getNumberOfBusinessDays(Date start, Date end){if (start == null || end == null)return 0;long daysWithoutSunday = 0;int w1 = 0;int w2 = 0;Calendar c1 = GregorianCalendar.getInstance();c1.setTime(start);w1 = c1.get(Calendar.DAY_OF_WEEK);c1.add(Calendar.DAY_OF_WEEK, -w1 + 1);Calendar c2 = GregorianCalendar.getInstance();c2.setTime(end);w2 = c2.get(Calendar.DAY_OF_WEEK);c2.add(Calendar.DAY_OF_WEEK, -w2 + 1);//end Saturday to start Saturdaylong days = (c2.getTimeInMillis() - c1.getTimeInMillis())/(1000*60*60*24);daysWithoutSunday = days-(days*2/7);if (w1 == Calendar.SUNDAY)w1 = Calendar.MONDAY;if (w2 == Calendar.SUNDAY)w2 = Calendar.MONDAY;return daysWithoutSunday-w1+w2;}
Subscribe to:
Comments (Atom)