`
gary0416
  • 浏览: 334704 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

获取指定月份的工作日天数

阅读更多
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中计算某个月的工作日总共几天

    该方法用于获取指定月份的第一天日期。 ```java public static String getMonthFirstDate(Date date) { if (date == null) { date = new Date(); } Calendar c = Calendar.getInstance(); c.setTime(date); ...

    c#计算当月工作日天数方法学习

    下面我们将详细探讨如何使用C#来计算指定月份的工作日天数。 首先,我们需要了解工作日的定义,通常工作日是指周一到周五,不包括周六和周日。在某些情况下,还需要排除法定节假日。在C#中,我们可以利用`DateTime`...

    oracle函数得到下一个法定工作日期

    首先,Oracle提供了一些内置的日期函数,如`SYSDATE`获取当前日期,`ADD_MONTHS`增加月份,`TRUNC`截断日期到指定的日期部分。然而,这些函数并不直接支持判断是否为工作日或法定假日。因此,我们通常需要结合其他...

    EXCEL获取2009年剩余所有周六的日期列表

    假设当前时间是在2009年的某个工作日,我们需要列出2009年剩下的所有周六的日期。这样的需求在很多场景下都会遇到,比如计划安排、数据分析等。为了实现这一目标,我们需要利用Excel中的函数组合来完成。 #### 二、...

    Date对象之获取和设置月份-getMonth&setMonth;(教辅).pdf

    此外,setMonth()还可接收第二个可选参数day,用于指定月份中的某一天,其取值范围是1至31。设置月份时,如果天数超过了该月份的天数,日期会自动进位到下个月。例如,设置月份为3月,天数为32,则日期会进位到4月的...

    Oracle sql查询当前月的所有日期

    `LAST_DAY()`用于获取指定日期所在月份的最后一天,而`NEXT_DAY()`用于获取指定日期之后的下一个工作日或特定星期几的日期。 - **`TO_CHAR()`函数的格式模型**:`TO_CHAR()`函数可以接受第二个参数指定日期或数字的...

    请假时长计算和每月工作天数计算源码

    Java提供了`YearMonth`类来处理月份,结合`DayOfWeek`可以判断是否为工作日。以下代码示例展示了如何计算一个月的工作日: ```java import java.time.*; public class MonthlyWorkingDaysCalculator { public ...

    LocalDate类获取日期和改变日期

    - `with(TemporalAdjuster adjuster)`使用调整器改变日期,如设置为下一个工作日。 5. **日期的格式化与解析** - 使用`DateTimeFormatter`类进行日期格式化,如`"yyyy-MM-dd"`。 - `format(DateTimeFormatter ...

    PHP获取指定日期是星期几的实现方法

    在实际应用中,可以使用这些函数结合进行更复杂的日期处理,比如计算两个日期之间的天数、获取某个日期是月份的第一天或最后一天、检查日期是否在某个范围内等等。PHP的日期和时间处理功能强大且灵活,能满足大多数...

    Java - DateUtil 日期时间转换工具类

    获取某天之后的下一个工作日;日期转毫秒数;将时间新增或减少对应日期等等。 资源功能:项目需要编写与时间转换相关的代码,使用该工具类可以简化开发。 适用人群:具有一定编程经验,能够看懂相关Date类,...

    数据库中日期时间用法

    `Last_day`函数可以帮助我们找到当前或者指定月份的最后一天,这对于月末的业务处理特别有帮助。 **示例代码**: ```sql SELECT last_day(sysdate) FROM dual; ``` 假设今天是6月20日,执行上述命令将返回“30-6...

    日序计算器

    3. 添加指定日期的天数:在总天数上加上指定月份的天数和指定日。 "DayOfYear计算器.exe"很可能就是这个工具的执行文件,用户双击运行后,通过简单的界面输入日期,即可得到日序结果。对于开发者而言,了解这种计算...

    VB周报表 月报表 年报表时间段设置

    若要得到上个月,可以先获取指定月份的上一月的天数,然后减去这个天数,如`DateSerial(年份, 月份, 1) - Day(DateSerial(年份, 月份, 0))`。 - **年报表**:年报表通常以每年的1月1日为开始,`DateSerial(年份, 1,...

    利用Excel公式计算上个月的考勤天数.rar

    要获取上个月的第一天,可以结合`EOMONTH`函数,它返回给定日期前或后的指定月份的最后一天。所以,如果我们要得到上个月的最后一天,可以对今天的日期使用`EOMONTH(-1)`。 假设当前单元格A1存储了当前日期(可以...

    利用Excel组合公式指定某月的第几周的天数.rar

    在Excel中,计算特定月份的第几周的天数是一项常见的任务,特别是在数据分析、日程管理和项目规划中。本示例以2007年5月为例,展示了如何利用Excel的组合公式来解决这个问题。首先,我们需要理解Excel中的日期系统...

    python3 实现计算年月的首天是周几及月份总天数

    在合法的月份内,`calendar.monthrange()`函数用于获取指定年份和月份的一些信息,返回一个元组,其中第一个元素表示月份第一天是星期几(0表示周一,1表示周二,以此类推),第二个元素是该月份的总天数。...

    PHP获取指定时间段之间的 年,月,天,时,分,秒

    例如,计算两个日期之间的日期数、工作日数、特定时间周期等。 总的来说,这段代码展示了如何通过自定义函数处理日期时间的转换和计算,适用于那些需要精确计算时间间隔的场景。理解并掌握这些基础知识对于进行PHP...

    SQL语句范例-有关日期的函数

    实现方式:结合闰年判断和月份天数计算,构建出指定月份的最后一天的日期对象。 应用:在财务会计、月度统计分析中,经常需要知道每个月的最后一天,以便进行截止日期的设定。 ### 7. 计算上个月的第一天 函数原型...

    SQL日期查询大全

    - `6 - datepart(day, GETDATE())`计算距离本周结束还有多少天。 - `dateadd(dd, x, date)`将x天添加到指定日期date上。 - `DATEDIFF(wk, 0, date)`计算当前日期与1900年1月1日之间的周数差。 - 结果为当前周的最后...

Global site tag (gtag.js) - Google Analytics