当前位置: 首页 > 面试题库 >

查找两个日期之间的日差(不包括周末)

孟凯泽
2023-03-14
问题内容

嗨,我正在使用jquery-uidatepicker选择date和date.js来查找两个日期之间的差异。

现在的问题是我想从计算中排除周末(周六和周日)。我该怎么办?

例如,用户选择开始日期(13/8/2010)和结束日期(16/8/2010)。由于14/8/2010和15/8/2010是工作日,而不是总共4天,所以我希望只有2天。

这是即时消息正在使用的代码:

<script type="text/javascript">

    $("#startdate, #enddate").change(function() {

    var d1 = $("#startdate").val();
    var d2 = $("#enddate").val();

            var minutes = 1000*60;
            var hours = minutes*60;
            var day = hours*24;

            var startdate1 = getDateFromFormat(d1, "d-m-y");
            var enddate1 = getDateFromFormat(d2, "d-m-y");

            var days = 1 + Math.round((enddate1 - startdate1)/day);

    if(days>0)
    { $("#noofdays").val(days);}
    else
    { $("#noofdays").val(0);}


    });

    </script>

问题答案:

也许其他人可以帮助您将此功能转换为JQuery的框架…

我在这里找到了这个功能。

function calcBusinessDays(dDate1, dDate2) { // input given as Date objects

  var iWeeks, iDateDiff, iAdjust = 0;

  if (dDate2 < dDate1) return -1; // error code if dates transposed

  var iWeekday1 = dDate1.getDay(); // day of week

  var iWeekday2 = dDate2.getDay();

  iWeekday1 = (iWeekday1 == 0) ? 7 : iWeekday1; // change Sunday from 0 to 7

  iWeekday2 = (iWeekday2 == 0) ? 7 : iWeekday2;

  if ((iWeekday1 > 5) && (iWeekday2 > 5)) iAdjust = 1; // adjustment if both days on weekend

  iWeekday1 = (iWeekday1 > 5) ? 5 : iWeekday1; // only count weekdays

  iWeekday2 = (iWeekday2 > 5) ? 5 : iWeekday2;



  // calculate differnece in weeks (1000mS * 60sec * 60min * 24hrs * 7 days = 604800000)

  iWeeks = Math.floor((dDate2.getTime() - dDate1.getTime()) / 604800000)



  if (iWeekday1 < iWeekday2) { //Equal to makes it reduce 5 days

    iDateDiff = (iWeeks * 5) + (iWeekday2 - iWeekday1)

  } else {

    iDateDiff = ((iWeeks + 1) * 5) - (iWeekday1 - iWeekday2)

  }



  iDateDiff -= iAdjust // take into account both days on weekend



  return (iDateDiff + 1); // add 1 because dates are inclusive

}



var date1 = new Date("August 11, 2010 11:13:00");

var date2 = new Date("August 16, 2010 11:13:00");

alert(calcBusinessDays(date1, date2));

##编辑

如果您想将其与该格式一起使用,请执行以下操作:

您的代码如下所示:

function calcBusinessDays(dDate1, dDate2) { // input given as Date objects

  var iWeeks, iDateDiff, iAdjust = 0;

  if (dDate2 < dDate1) return -1; // error code if dates transposed

  var iWeekday1 = dDate1.getDay(); // day of week

  var iWeekday2 = dDate2.getDay();

  iWeekday1 = (iWeekday1 == 0) ? 7 : iWeekday1; // change Sunday from 0 to 7

  iWeekday2 = (iWeekday2 == 0) ? 7 : iWeekday2;

  if ((iWeekday1 > 5) && (iWeekday2 > 5)) iAdjust = 1; // adjustment if both days on weekend

  iWeekday1 = (iWeekday1 > 5) ? 5 : iWeekday1; // only count weekdays

  iWeekday2 = (iWeekday2 > 5) ? 5 : iWeekday2;



  // calculate differnece in weeks (1000mS * 60sec * 60min * 24hrs * 7 days = 604800000)

  iWeeks = Math.floor((dDate2.getTime() - dDate1.getTime()) / 604800000)



  if (iWeekday1 < iWeekday2) { //Equal to makes it reduce 5 days

    iDateDiff = (iWeeks * 5) + (iWeekday2 - iWeekday1)

  } else {

    iDateDiff = ((iWeeks + 1) * 5) - (iWeekday1 - iWeekday2)

  }



  iDateDiff -= iAdjust // take into account both days on weekend



  return (iDateDiff + 1); // add 1 because dates are inclusive

}





$("#startdate, #enddate").change(function() {



  var d1 = $("#startdate").val();

  var d2 = $("#enddate").val();



  var minutes = 1000 * 60;

  var hours = minutes * 60;

  var day = hours * 24;



  var startdate1 = new Date(d1);

  var enddate1 = new Date(d2);





  var newstartdate = new Date();

  newstartdate.setFullYear(startdate1.getYear(), startdate1.getMonth(), startdate1.getDay());

  var newenddate = new Date();

  newenddate.setFullYear(enddate1.getYear(), enddate1.getMonth(), enddate1.getDay());

  var days = calcBusinessDays(newstartdate, newenddate);

  if (days > 0) {

    $("#noofdays").val(days);

  } else {

    $("#noofdays").val(0);

  }

});


<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>



<label>Start Date

 <input type="date" id="startdate" value="2019-03-03"/>

</label>



<label>End Date

 <input type="date" id="enddate" value="2019-03-06"/>

</label>



<label>N. of days

 <output id="noofdays"/>

</label>


 类似资料:
  • 问题内容: 如何获得两个工作日之间的工作天数,即不包括周末和节假日?假期是指法律认可的假期。由于每个国家/地区的假期不同,因此必须取决于国家/地区。 例如,由于介于两者之间的周末,应返回而不是。 我已经看过Jollyday和ObjectLab- Kit ,但是我不能让它们满足我的需要。我的意思是,他们两个都有很多有趣的方法,但是找不到类似…的东西。 问题答案: 最后是基于API 的解决方案: 致电

  • 问题内容: 给定以下日期: 和一个静态变量: 我需要创建一个数组,如: 周末除外。 不,这不是功课…出于某种原因,我今天无法直截了当。 问题答案: 对于PHP> = 5.3.0,请使用DatePeriod类。不幸的是,几乎没有记录。

  • 问题内容: 我在Spring 3.0项目中使用Joda time api计算日期。现在我有一个开始日期和结束日期,我想在这两个日期之间得到每天的周末,星期六或星期日。我该如何实现? 我看了这篇Joda的时间-两个日期之间的所有星期一。它提供了一些指导,但在如何排除两个日期方面仍然含糊。 问题答案: 我想你的问题是如何 在两个日期之间的周末,星期六或星期日除外的每一天获取。 解决方案 :

  • 问题内容: 我需要计算MySQL中两个日期之间的差异(以天为单位),不包括周末(星期六和星期日)。也就是说,天数差减去两者之间的周六和周日数。 目前,我只是使用以下方法计算天数: 此收益,但我想排除周末,所以我想(因为第3和4、10、11和17日是周末)。 我不知道从哪里开始。我知道该功能和所有相关功能,但是我不知道如何在此上下文中使用它们。 问题答案: 插图: 伪代码:

  • 问题内容: 我有一个代码,可以使用np.busdaycount计算除周末以外的日期差异,但是我需要在我无法获得的小时数内。 除周末外,我的工作时间为小时。喜欢 问题 Inflow_date_time = 2019-08-01 23:22:46 End_date_time = 2019-08-05 17:43:51预期小时数42小时(1 + 24 + 17) Inflow_date_time = 2

  • 问题内容: 嗨,我尝试使用此代码进行几天工作(包括周末),因此如何排除两个日期之间的周末? 问题答案: 这对你有用 现场演示 放出