package com.gary.util;
import java.util.Calendar;
/**
* 日期工具
* @author gary
*
*/
public class DateUtil {
/**
* 计算两个日期的相隔天数
* @param d1
* @param d2
* @return
*/
public static int getDaysBetween(Calendar d1, Calendar d2) {
if (d1.after(d2)) {
Calendar swap = d1;
d1 = d2;
d2 = swap;
}
int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR);
int y2 = d2.get(Calendar.YEAR);
if (d1.get(Calendar.YEAR) != y2) {
d1 = (Calendar) d1.clone();
do {
days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);
d1.add(Calendar.YEAR, 1);
} while (d1.get(Calendar.YEAR) != y2);
}
return days;
}
/**
* 计算2个日期之间的工作日相隔天数
* @param d1
* @param d2
* @return
*/
public static int getWorkingDay(Calendar d1, Calendar d2) {
int result = -1;
if (d1.after(d2)) {
Calendar swap = d1;
d1 = d2;
d2 = swap;
}
//开始日期的日期偏移量
int charge_start_date = 0;
//结束日期的日期偏移量
int charge_end_date = 0;
// 日期不在同一个日期内
int stmp;
int etmp;
stmp = 7 - d1.get(Calendar.DAY_OF_WEEK);
etmp = 7 - d2.get(Calendar.DAY_OF_WEEK);
// 开始日期为星期六和星期日时偏移量为0
if (stmp != 0 && stmp != 6) {
charge_start_date = stmp - 1;
}
// 结束日期为星期六和星期日时偏移量为0
if (etmp != 0 && etmp != 6) {
charge_end_date = etmp - 1;
}
result = (getDaysBetween(getNextMonday(d1), getNextMonday(d2)) / 7)
* 5 + charge_start_date - charge_end_date;
return result + 1;
}
/**
* 获得日期的下一个星期一的日期
* @param date
* @return
*/
public static Calendar getNextMonday(Calendar date) {
Calendar result = null;
result = date;
do {
result = (Calendar) result.clone();
result.add(Calendar.DATE, 1);
} while (result.get(Calendar.DAY_OF_WEEK) != 2);
return result;
}
/**
* 获取指定年-月(yyyy-mm)的工作日天数
* @param year_month
* @return
*/
public static int getWorkingDayOfMonth(String year_month){
int year = Integer.parseInt(year_month.substring(0,year_month.indexOf("-")));
int month = Integer.parseInt(year_month.substring(year_month.indexOf("-") + 1));
Calendar start = Calendar.getInstance();
start.clear();
start.set(Calendar.YEAR, year);
start.set(Calendar.MONTH, month - 1);
start.set(Calendar.DAY_OF_MONTH, 1);
Calendar end = Calendar.getInstance();
end.clear();
end = (Calendar) start.clone();
end.add(Calendar.MONTH,1);
end.add(Calendar.DAY_OF_MONTH,-1);
return getWorkingDay(start,end);
}
/**
* Test
* @param args
*/
public static void main(String[] args) {
System.out.println(getWorkingDayOfMonth("2010-1"));
System.out.println(getWorkingDayOfMonth("2010-02"));
System.out.println(getWorkingDayOfMonth("2010-12"));
}
}
分享到:
相关推荐
该方法用于获取指定月份的第一天日期。 ```java public static String getMonthFirstDate(Date date) { if (date == null) { date = new Date(); } Calendar c = Calendar.getInstance(); c.setTime(date); ...
下面我们将详细探讨如何使用C#来计算指定月份的工作日天数。 首先,我们需要了解工作日的定义,通常工作日是指周一到周五,不包括周六和周日。在某些情况下,还需要排除法定节假日。在C#中,我们可以利用`DateTime`...
首先,Oracle提供了一些内置的日期函数,如`SYSDATE`获取当前日期,`ADD_MONTHS`增加月份,`TRUNC`截断日期到指定的日期部分。然而,这些函数并不直接支持判断是否为工作日或法定假日。因此,我们通常需要结合其他...
假设当前时间是在2009年的某个工作日,我们需要列出2009年剩下的所有周六的日期。这样的需求在很多场景下都会遇到,比如计划安排、数据分析等。为了实现这一目标,我们需要利用Excel中的函数组合来完成。 #### 二、...
此外,setMonth()还可接收第二个可选参数day,用于指定月份中的某一天,其取值范围是1至31。设置月份时,如果天数超过了该月份的天数,日期会自动进位到下个月。例如,设置月份为3月,天数为32,则日期会进位到4月的...
`LAST_DAY()`用于获取指定日期所在月份的最后一天,而`NEXT_DAY()`用于获取指定日期之后的下一个工作日或特定星期几的日期。 - **`TO_CHAR()`函数的格式模型**:`TO_CHAR()`函数可以接受第二个参数指定日期或数字的...
Java提供了`YearMonth`类来处理月份,结合`DayOfWeek`可以判断是否为工作日。以下代码示例展示了如何计算一个月的工作日: ```java import java.time.*; public class MonthlyWorkingDaysCalculator { public ...
- `with(TemporalAdjuster adjuster)`使用调整器改变日期,如设置为下一个工作日。 5. **日期的格式化与解析** - 使用`DateTimeFormatter`类进行日期格式化,如`"yyyy-MM-dd"`。 - `format(DateTimeFormatter ...
在实际应用中,可以使用这些函数结合进行更复杂的日期处理,比如计算两个日期之间的天数、获取某个日期是月份的第一天或最后一天、检查日期是否在某个范围内等等。PHP的日期和时间处理功能强大且灵活,能满足大多数...
获取某天之后的下一个工作日;日期转毫秒数;将时间新增或减少对应日期等等。 资源功能:项目需要编写与时间转换相关的代码,使用该工具类可以简化开发。 适用人群:具有一定编程经验,能够看懂相关Date类,...
`Last_day`函数可以帮助我们找到当前或者指定月份的最后一天,这对于月末的业务处理特别有帮助。 **示例代码**: ```sql SELECT last_day(sysdate) FROM dual; ``` 假设今天是6月20日,执行上述命令将返回“30-6...
3. 添加指定日期的天数:在总天数上加上指定月份的天数和指定日。 "DayOfYear计算器.exe"很可能就是这个工具的执行文件,用户双击运行后,通过简单的界面输入日期,即可得到日序结果。对于开发者而言,了解这种计算...
若要得到上个月,可以先获取指定月份的上一月的天数,然后减去这个天数,如`DateSerial(年份, 月份, 1) - Day(DateSerial(年份, 月份, 0))`。 - **年报表**:年报表通常以每年的1月1日为开始,`DateSerial(年份, 1,...
要获取上个月的第一天,可以结合`EOMONTH`函数,它返回给定日期前或后的指定月份的最后一天。所以,如果我们要得到上个月的最后一天,可以对今天的日期使用`EOMONTH(-1)`。 假设当前单元格A1存储了当前日期(可以...
在Excel中,计算特定月份的第几周的天数是一项常见的任务,特别是在数据分析、日程管理和项目规划中。本示例以2007年5月为例,展示了如何利用Excel的组合公式来解决这个问题。首先,我们需要理解Excel中的日期系统...
在合法的月份内,`calendar.monthrange()`函数用于获取指定年份和月份的一些信息,返回一个元组,其中第一个元素表示月份第一天是星期几(0表示周一,1表示周二,以此类推),第二个元素是该月份的总天数。...
例如,计算两个日期之间的日期数、工作日数、特定时间周期等。 总的来说,这段代码展示了如何通过自定义函数处理日期时间的转换和计算,适用于那些需要精确计算时间间隔的场景。理解并掌握这些基础知识对于进行PHP...
实现方式:结合闰年判断和月份天数计算,构建出指定月份的最后一天的日期对象。 应用:在财务会计、月度统计分析中,经常需要知道每个月的最后一天,以便进行截止日期的设定。 ### 7. 计算上个月的第一天 函数原型...
- `6 - datepart(day, GETDATE())`计算距离本周结束还有多少天。 - `dateadd(dd, x, date)`将x天添加到指定日期date上。 - `DATEDIFF(wk, 0, date)`计算当前日期与1900年1月1日之间的周数差。 - 结果为当前周的最后...