转帖地址:http://blog.csdn.net/kongjiea/article/details/46829023
1、首先来一个自己公司项目的源码:
项目需求描述: 从20150712日开始, ,
需求①:根据当前时间返回每一周 、周一~周日的日期(需返回2种格式 格式1:7月13日,格式2:2015-07-13)
需求②:返回当前时间本周的,周一早上9:00:00和周日的23:59:59
需求③:计算出当前时间离20150712日有多少周
需求④:在需求3基础上,如果大于一周,需要返回历史周的周一早上9:00:00和周日的23:59:59 (在此用二位数组)
- function GetWeekDate(time){
- var now = new Date(time); //当前日期
- this.nowDayOfWeek = now.getDay(); //今天本周的第几天
- this.nowYear = now.getYear(); //当前年
- this.nowMonth = now.getMonth(); //月
- this.nowDay = now.getDate(); //日
- this.beginHour="09:00:00";
- this.endHour="23:59:59";
- this.nowYear += (this.nowYear < 2000) ? 1900 : 0; //
- this.nowDayOfWeek = this.nowDayOfWeek==0?7:this.nowDayOfWeek; // 如果是周日,就变成周七
- }
- GetWeekDate.prototype.date2str=function(x,y){//date2str(new Date(curTime),"yyyy-MM-dd")
- var z ={y:x.getFullYear(),M:x.getMonth()+1,d:x.getDate(),h:x.getHours(),m:x.getMinutes(),s:x.getSeconds()};
- return y.replace(/(y+|M+|d+|h+|m+|s+)/g,function(v) {return ((v.length>1?"0":"")+eval('z.'+v.slice(-1))).slice(-(v.length>2?v.length:2))});
- }
- GetWeekDate.prototype.formatDate=function(date){//格局化日期:yyyy-MM-dd
- var myyear = date.getFullYear();
- var mymonth = date.getMonth()+1;
- var myweekday = date.getDate();
- //alert("formatDate"+myyear+":"+mymonth+":"+myweekday)
- if(mymonth < 10){
- mymonth = "0" + mymonth;
- }
- if(myweekday < 10){
- myweekday = "0" + myweekday;
- }
- return (myyear+"-"+mymonth + "-" + myweekday);
- }
- GetWeekDate.prototype.getWeekStartDate=function(){ //获得本周的开端日期
- var weekStartDate = new Date(this.nowYear, this.nowMonth, this.nowDay - this.nowDayOfWeek+1);
- return this.formatDate(weekStartDate);
- }
- GetWeekDate.prototype.getWeekEndDate=function(){//获得本周的停止日期
- var weekEndDate = new Date(this.nowYear, this.nowMonth, this.nowDay + (6 - this.nowDayOfWeek+1));
- return this.formatDate(weekEndDate);
- }
- GetWeekDate.prototype.getAWeedkYMD=function(){//获得本周周一~周日的年月日
- var ymdArr=[];
- for (var i = 0; i < 7; i++) {
- ymdArr[i]=[];
- //ymdArr[i][0]=this.formatDate(new Date(this.nowYear, this.nowMonth, this.nowDay - this.nowDayOfWeek+i+1));
- ymdArr[i][0]=this.date2str(new Date(this.nowYear, this.nowMonth, this.nowDay - this.nowDayOfWeek+i+1),'yyyy-MM-dd');
- ymdArr[i][1]=this.date2str(new Date(this.nowYear, this.nowMonth, this.nowDay - this.nowDayOfWeek+i+1), 'MM月dd日');
- };
- return ymdArr;
- }
- GetWeekDate.prototype.getQishu=function(time){//获得本周是指定日期(7.12日)的第几周
- var oNDate=new Date(time); //系统当前时间
- var oEDate=new Date('2015/7/12 23:59:59');
- var diff= oNDate.getTime()-oEDate.getTime();
- //console.log(diff)
- //console.log("相差天:"+diff/(24*60*60*1000))
- //console.log("相差期数:"+parseInt(diff/(24*60*60*1000))/7)
- //console.log("取整期数:"+Math.floor(parseInt(diff/(24*60*60*1000))/7))
- return (diff/(24*60*60*1000))/7;
- }
- GetWeekDate.prototype.getWeeksDates=function(time){//获取历史周排行的周一到周日时间段
- var qishu = (this.qishu || this.qishu==0)?this.qishu:this.getQishu(time);
- //var qishu=this.getQishu(time);
- var WeeksTimes=[];//存放时间的二维数组
- minYear=2015,
- minMonth=7,
- minDay=12;
- for (var i = 0; i<qishu; i++) {
- var sday;
- var eday;
- WeeksTimes[i]=[];
- if(i==0){//如果离2015-07-12只相差1期
- sday=minDay+1; //开始时间+1天
- }else{//如果离2015-07-12相差期数>1
- sday=minDay+1+7*i;
- }
- eday=minDay+7*(i+1);//结束时间+7天
- WeeksTimes[i][0]=this.formatDate(new Date(minYear,minMonth-1,sday))+" "+this.beginHour;
- WeeksTimes[i][1]=this.formatDate(new Date(minYear,minMonth-1,eday))+" "+this.endHour;
- };
- //如果是一周的周日就不要减去一期
- return WeeksTimes;
- }
- GetWeekDate.prototype.todayData=function(json){//处理tender_list_week.jsp页面
- var oQishu=$('.qishu');
- iQishu=this.qishu;//期数+1是因为,相差0期就是第1期
- oThisWeekListBtn=$('.total_list_btn'),//查看本周排行榜按钮
- sTime=this.getWeekStartDate()+" "+this.beginHour,
- eTime=this.getWeekEndDate()+" "+this.endHour;
- //1、修改期数
- //console.log("相差周:"+iQishu);
- if(/^[1-9]\d*$/.test(iQishu) || iQishu==0){//整数 +3
- oQishu.html(iQishu*1+3);
- }else{
- oQishu.html(Math.floor(iQishu)*1+4);
- }
- oThisWeekListBtn.attr("onclick","showWeekList('"+sTime+"','"+eTime+"')");//2、修改查看本周排行榜的起止时间
- }
- GetWeekDate.prototype.historyData=function(time){//处理tender_list_week.jsp页面
- var oQishu=$('.qishu'),
- oDateList=$('#dateList'), //顶部导航时间
- oHistoryList=$('#history_cont'),//历史周
- aThisWeekYMD=this.getAWeedkYMD(),//本周周一~周日的年月日
- aThisWeekDates=this.getWeeksDates(time);//获取历史周排行的周一到周日时间段
- iQishu=this.qishu;
- //console.log("相差周:"+iQishu);
- //1、修改期数,+4是加上前3期,在+1是如果间隔3期,当前就是第4期
- //如果时间23:59:59是正整数(-1),如果是0整数(3),如果是非整数(向下取整),或负数(向上取整)但是负数不考虑
- //oQishu.html(iQishu*1+3);
- if(/^[1-9]\d*$/.test(iQishu) || iQishu==0){//整数 +3
- oQishu.html(iQishu*1+3);
- }else{
- oQishu.html(Math.floor(iQishu)*1+4);
- }
- //2、给顶部时间追加时间
- for (var i = 0; i < aThisWeekYMD.length; i++) {
- var str='<li data-time="'+aThisWeekYMD[i][0]+'">'+aThisWeekYMD[i][1]+'</li>';
- $(str).appendTo(oDateList);
- };
- //3、给历史周排行榜添加周期数
- if(this.qishu>1){//如果相差的期数大于1期
- //console.dir(aThisWeekDates)
- for (var j = 0; j < aThisWeekDates.length-1; j++) {
- var iQiNum=j+4;
- var str='<li onclick="showWeekList(\''+aThisWeekDates[j][0]+'\',\''+aThisWeekDates[j][1]+'\')">第'+iQiNum+'期</li>';
- $(str).prependTo(oHistoryList);
- };
- }
- }
- GetWeekDate.prototype.init=function(time){
- var iQishu=this.getQishu(time),//期数+1是因为,相差0期就是第1期
- json={};
- json.qishu=iQishu;
- this.qishu=iQishu;
- if($('#pageType').val()=="today"){//如果是tender_list_week.jsp页面
- if(new Date(time).getTime() < new Date('2015/07/12 23:59:59').getTime()){//特殊处理时间小于20150712
- $('.qishu').html('3');
- $('.total_list_btn').attr("onclick","showWeekList('2015-07-03 09:00:00','2015-07-12 23:59:59')");
- return false;
- }
- this.todayData(json);
- }else if($('#pageType').val()=="history"){
- if(new Date(time).getTime() < new Date('2015/07/12 23:59:59').getTime()){//特殊处理时间小于20150712
- $('.qishu').html('3');
- $('#dateList').addClass('dateList2').html('<li data-time="2015-07-03">07月03日</li><li data-time="2015-07-04">07月04日</li><li data-time="2015-07-05">07月05日</li><li data-time="2015-07-06">07月06日</li><li data-time="2015-07-07">07月07日</li><li data-time="2015-07-08">07月08日</li><li data-time="2015-07-09">07月09日</li><li data-time="2015-07-10">07月10日</li><li data-time="2015-07-11">07月11日</li><li data-time="2015-07-12">07月12日</li>');
- $('#history_cont').html('<li onclick="showWeekList(\'2015-06-26 09:00:00\',\'2015-07-02 23:59:59\')">第二期</li><li onclick="showWeekList(\'2015-06-19 12:00:00\',\'2015-06-25 23:59:59\')">第一期</li>');
- return false;
- }
- this.historyData(time);
- }
- //console.dir(this.getWeeksDates(time));
- };
2、JS获取本周、本季度、本月、上月的开端日期、停止日期
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8" />
- <title>Document</title>
- <script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.min.js"></script>
- <script>
- /**
- * 日期范围工具类
- */
- var dateRangeUtil = (function () {
- /***
- * 获得当前时间
- */
- this.getCurrentDate = function () {
- return new Date('2015','07','-1');
- };
- /***
- * 获得本周起止时间
- */
- this.getCurrentWeek = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //返回date是一周中的某一天
- var week = currentDate.getDay();
- //返回date是一个月中的某一天
- var month = currentDate.getDate();
- //一天的毫秒数
- var millisecond = 1000 * 60 * 60 * 24;
- //减去的天数
- var minusDay = week != 0 ? week - 1 : 6;
- //alert(minusDay);
- //本周 周一
- var monday = new Date(currentDate.getTime() - (minusDay * millisecond));
- //本周 周日
- var sunday = new Date(monday.getTime() + (6 * millisecond));
- //添加本周时间
- startStop.push(monday); //本周起始时间
- //添加本周最后一天时间
- startStop.push(sunday); //本周终止时间
- //返回
- return startStop;
- };
- /***
- * 获得本月的起止时间
- */
- this.getCurrentMonth = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前月份0-11
- var currentMonth = currentDate.getMonth();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- //求出本月第一天
- var firstDay = new Date(currentYear, currentMonth, 1);
- //当为12月的时候年份需要加1
- //月份需要更新为0 也就是下一年的第一个月
- if (currentMonth == 11) {
- currentYear++;
- currentMonth = 0; //就为
- } else {
- //否则只是月份增加,以便求的下一月的第一天
- currentMonth++;
- }
- //一天的毫秒数
- var millisecond = 1000 * 60 * 60 * 24;
- //下月的第一天
- var nextMonthDayOne = new Date(currentYear, currentMonth, 1);
- //求出上月的最后一天
- var lastDay = new Date(nextMonthDayOne.getTime() - millisecond);
- //添加至数组中返回
- startStop.push(firstDay);
- startStop.push(lastDay);
- //返回
- return startStop;
- };
- /**
- * 得到本季度开始的月份
- * @param month 需要计算的月份
- ***/
- this.getQuarterSeasonStartMonth = function (month) {
- var quarterMonthStart = 0;
- var spring = 0; //春
- var summer = 3; //夏
- var fall = 6; //秋
- var winter = 9; //冬
- //月份从0-11
- if (month < 3) {
- return spring;
- }
- if (month < 6) {
- return summer;
- }
- if (month < 9) {
- return fall;
- }
- return winter;
- };
- /**
- * 获得该月的天数
- * @param year年份
- * @param month月份
- * */
- this.getMonthDays = function (year, month) {
- //本月第一天 1-31
- var relativeDate = new Date(year, month, 1);
- //获得当前月份0-11
- var relativeMonth = relativeDate.getMonth();
- //获得当前年份4位年
- var relativeYear = relativeDate.getFullYear();
- //当为12月的时候年份需要加1
- //月份需要更新为0 也就是下一年的第一个月
- if (relativeMonth == 11) {
- relativeYear++;
- relativeMonth = 0;
- } else {
- //否则只是月份增加,以便求的下一月的第一天
- relativeMonth++;
- }
- //一天的毫秒数
- var millisecond = 1000 * 60 * 60 * 24;
- //下月的第一天
- var nextMonthDayOne = new Date(relativeYear, relativeMonth, 1);
- //返回得到上月的最后一天,也就是本月总天数
- return new Date(nextMonthDayOne.getTime() - millisecond).getDate();
- };
- /**
- * 获得本季度的起止日期
- */
- this.getCurrentSeason = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前月份0-11
- var currentMonth = currentDate.getMonth();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- //获得本季度开始月份
- var quarterSeasonStartMonth = this.getQuarterSeasonStartMonth(currentMonth);
- //获得本季度结束月份
- var quarterSeasonEndMonth = quarterSeasonStartMonth + 2;
- //获得本季度开始的日期
- var quarterSeasonStartDate = new Date(currentYear, quarterSeasonStartMonth, 1);
- //获得本季度结束的日期
- var quarterSeasonEndDate = new Date(currentYear, quarterSeasonEndMonth, this.getMonthDays(currentYear, quarterSeasonEndMonth));
- //加入数组返回
- startStop.push(quarterSeasonStartDate);
- startStop.push(quarterSeasonEndDate);
- //返回
- return startStop;
- };
- /***
- * 得到本年的起止日期
- *
- */
- this.getCurrentYear = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- //本年第一天
- var currentYearFirstDate = new Date(currentYear, 0, 1);
- //本年最后一天
- var currentYearLastDate = new Date(currentYear, 11, 31);
- //添加至数组
- startStop.push(currentYearFirstDate);
- startStop.push(currentYearLastDate);
- //返回
- return startStop;
- };
- /**
- * 返回上一个月的第一天Date类型
- * @param year 年
- * @param month 月
- **/
- this.getPriorMonthFirstDay = function (year, month) {
- //年份为0代表,是本年的第一月,所以不能减
- if (month == 0) {
- month = 11; //月份为上年的最后月份
- year--; //年份减1
- return new Date(year, month, 1);
- }
- //否则,只减去月份
- month--;
- return new Date(year, month, 1); ;
- };
- /**
- * 获得上一月的起止日期
- * ***/
- this.getPreviousMonth = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前月份0-11
- var currentMonth = currentDate.getMonth();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- //获得上一个月的第一天
- var priorMonthFirstDay = this.getPriorMonthFirstDay(currentYear, currentMonth);
- //获得上一月的最后一天
- var priorMonthLastDay = new Date(priorMonthFirstDay.getFullYear(), priorMonthFirstDay.getMonth(), this.getMonthDays(priorMonthFirstDay.getFullYear(), priorMonthFirstDay.getMonth()));
- //添加至数组
- startStop.push(priorMonthFirstDay);
- startStop.push(priorMonthLastDay);
- //返回
- return startStop;
- };
- /**
- * 获得上一周的起止日期
- * **/
- this.getPreviousWeek = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //返回date是一周中的某一天
- var week = currentDate.getDay();
- //返回date是一个月中的某一天
- var month = currentDate.getDate();
- //一天的毫秒数
- var millisecond = 1000 * 60 * 60 * 24;
- //减去的天数
- var minusDay = week != 0 ? week - 1 : 6;
- //获得当前周的第一天
- var currentWeekDayOne = new Date(currentDate.getTime() - (millisecond * minusDay));
- //上周最后一天即本周开始的前一天
- var priorWeekLastDay = new Date(currentWeekDayOne.getTime() - millisecond);
- //上周的第一天
- var priorWeekFirstDay = new Date(priorWeekLastDay.getTime() - (millisecond * 6));
- //添加至数组
- startStop.push(priorWeekFirstDay);
- startStop.push(priorWeekLastDay);
- return startStop;
- };
- /**
- * 得到上季度的起始日期
- * year 这个年应该是运算后得到的当前本季度的年份
- * month 这个应该是运算后得到的当前季度的开始月份
- * */
- this.getPriorSeasonFirstDay = function (year, month) {
- var quarterMonthStart = 0;
- var spring = 0; //春
- var summer = 3; //夏
- var fall = 6; //秋
- var winter = 9; //冬
- //月份从0-11
- switch (month) {//季度的其实月份
- case spring:
- //如果是第一季度则应该到去年的冬季
- year--;
- month = winter;
- break;
- case summer:
- month = spring;
- break;
- case fall:
- month = summer;
- break;
- case winter:
- month = fall;
- break;
- };
- return new Date(year, month, 1);
- };
- /**
- * 得到上季度的起止日期
- * **/
- this.getPreviousSeason = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前月份0-11
- var currentMonth = currentDate.getMonth();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- //上季度的第一天
- var priorSeasonFirstDay = this.getPriorSeasonFirstDay(currentYear, currentMonth);
- //上季度的最后一天
- var priorSeasonLastDay = new Date(priorSeasonFirstDay.getFullYear(), priorSeasonFirstDay.getMonth() + 2, this.getMonthDays(priorSeasonFirstDay.getFullYear(), priorSeasonFirstDay.getMonth() + 2));
- //添加至数组
- startStop.push(priorSeasonFirstDay);
- startStop.push(priorSeasonLastDay);
- return startStop;
- };
- /**
- * 得到去年的起止日期
- * **/
- this.getPreviousYear = function () {
- //起止日期数组
- var startStop = new Array();
- //获取当前时间
- var currentDate = this.getCurrentDate();
- //获得当前年份4位年
- var currentYear = currentDate.getFullYear();
- currentYear--;
- var priorYearFirstDay = new Date(currentYear, 0, 1);
- var priorYearLastDay = new Date(currentYear, 11, 1);
- //添加至数组
- startStop.push(priorYearFirstDay);
- startStop.push(priorYearLastDay);
- return startStop;
- };
- return this;
- })();
- $(function(){
- $("#startDate").html( dateRangeUtil.getCurrentWeek() );
- })
- </script>
- </head>
- <body>
- <div id="startDate"></div>
- </body>
- </html>
3、JS获取本周、本季度、本月、上月的开端日期、停止日期
- Js代码
- /**
- * 获取本周、本季度、本月、上月的开端日期、停止日期
- */
- var now = new Date(); //当前日期
- var nowDayOfWeek = now.getDay(); //今天本周的第几天
- var nowDay = now.getDate(); //当前日
- var nowMonth = now.getMonth(); //当前月
- var nowYear = now.getYear(); //当前年
- nowYear += (nowYear < 2000) ? 1900 : 0; //
- var lastMonthDate = new Date(); //上月日期
- lastMonthDate.setDate(1);
- lastMonthDate.setMonth(lastMonthDate.getMonth()-1);
- var lastYear = lastMonthDate.getYear();
- var lastMonth = lastMonthDate.getMonth();
- //格局化日期:yyyy-MM-dd
- function formatDate(date) {
- var myyear = date.getFullYear();
- var mymonth = date.getMonth()+1;
- var myweekday = date.getDate();
- if(mymonth < 10){
- mymonth = "0" + mymonth;
- }
- if(myweekday < 10){
- myweekday = "0" + myweekday;
- }
- return (myyear+"-"+mymonth + "-" + myweekday);
- }
- //获得某月的天数
- function getMonthDays(myMonth){
- var monthStartDate = new Date(nowYear, myMonth, 1);
- var monthEndDate = new Date(nowYear, myMonth + 1, 1);
- var days = (monthEndDate - monthStartDate)/(1000 * 60 * 60 * 24);
- return days;
- }
- //获得本季度的开端月份
- function getQuarterStartMonth(){
- var quarterStartMonth = 0;
- if(nowMonth<3){
- quarterStartMonth = 0;
- }
- if(2<nowMonth && nowMonth<6){
- quarterStartMonth = 3;
- }
- if(5<nowMonth && nowMonth<9){
- quarterStartMonth = 6;
- }
- if(nowMonth>8){
- quarterStartMonth = 9;
- }
- return quarterStartMonth;
- }
- //获得本周的开端日期
- function getWeekStartDate() {
- var weekStartDate = new Date(nowYear, nowMonth, nowDay - nowDayOfWeek);
- return formatDate(weekStartDate);
- }
- //获得本周的停止日期
- function getWeekEndDate() {
- var weekEndDate = new Date(nowYear, nowMonth, nowDay + (6 - nowDayOfWeek));
- return formatDate(weekEndDate);
- }
- //获得本月的开端日期
- function getMonthStartDate(){
- var monthStartDate = new Date(nowYear, nowMonth, 1);
- return formatDate(monthStartDate);
- }
- //获得本月的停止日期
- function getMonthEndDate(){
- var monthEndDate = new Date(nowYear, nowMonth, getMonthDays(nowMonth));
- return formatDate(monthEndDate);
- }
- //获得上月开端时候
- function getLastMonthStartDate(){
- var lastMonthStartDate = new Date(nowYear, lastMonth, 1);
- return formatDate(lastMonthStartDate);
- }
- //获得上月停止时候
- function getLastMonthEndDate(){
- var lastMonthEndDate = new Date(nowYear, lastMonth, getMonthDays(lastMonth));
- return formatDate(lastMonthEndDate);
- }
- //获得本季度的开端日期
- function getQuarterStartDate(){
- var quarterStartDate = new Date(nowYear, getQuarterStartMonth(), 1);
- return formatDate(quarterStartDate);
- }
- //或的本季度的停止日期
- function getQuarterEndDate(){
- var quarterEndMonth = getQuarterStartMonth() + 2;
- var quarterStartDate = new Date(nowYear, quarterEndMonth, getMonthDays(quarterEndMonth));
- return formatDate(quarterStartDate);
- }
相关推荐
在PHP编程中,获取特定时间范围的日期是常见的需求,比如获取本周、上周、本月、上月以及本季度的日期范围。这些功能可以帮助开发者在处理数据统计、报表生成或者时间相关的业务逻辑时更加便捷。下面将详细介绍如何...
本文将深入探讨如何使用C#中的DateTime类来获取当前时间,并基于此计算本周、本月、本季度以及月初、月末等各个时间段的具体日期。这对于进行时间序列数据分析、报表生成、日程安排等多种场景都具有重要的应用价值。...
Java 获取上月、一个月最后一天、周一、周日、本月日期是 Java 日期处理中的一些常见操作。下面我们将详细介绍这些操作的实现方法。 一、获取上月 获取上月可以使用 Calendar 类的 add 方法,减去一个月份。然后...
在JavaScript中,获取特定时间范围(如本周、上周、本月、上月、本季度、上季度)的开始和结束日期是常见的需求。以下是一个详细解释这些功能的实现方法: 首先,我们创建一个`Date`对象`now`来获取当前日期和时间...
Javascript获取上月、下月 var arr = date.split('-'); var year = arr[0]; //获取当前日期的年份 var month = arr[1]; //获取当前日期的月份 //var day = arr[2]; //获取当前日期的日 //var days = new Date...
本文将介绍如何使用JavaScript获取特定时间单位(如本周、本季度、本月、上月)的开始和结束日期。 首先,我们需要了解JavaScript中Date对象的基本概念。Date对象用于处理日期和时间,它提供了很多方法来获取和设置...
SQL 语句查询本周记录、本月记录、本季度记录、本年记录是数据库查询中常见的操作。本文将为您提供 MySQL 和 SQL Server 两种数据库管理系统的查询语句,帮助您快速实现这些查询操作。 查询本周记录 MySQL 中,您...
4. 日期计算:在代码中,我们可以看到日期计算的实现,例如获取上个月的25号、本月的24号、本月的1号、本月的最后一天等。这些日期计算可以帮助我们实现业务逻辑中的日期处理。 5. 日期比较:在代码中,我们可以...
- `startWeek`计算本周的第一天(即周一),通过获取当前日期`dt`,并根据当前是星期几来调整天数。例如,如果当前是星期三,则需要向前调整两天才能得到周一。 - `endWeek`则是在`startWeek`的基础上增加六天,即...
在JavaScript编程中,获取特定时间范围的日期是一个常见的需求,比如获取今天、昨天、本周、上周、本月和上月的时间。以下将详细解释如何通过JavaScript实现这些功能。 1. 获取今天: ```javascript var nowDate = ...
此外,这个方法也可以扩展到其他类似的需求,比如获取上周、本月、上月、本季度的日期,甚至计算一段日期内的周末天数等。通过结合不同的日期运算和条件判断,我们可以构建更复杂的日期处理逻辑。 总之,PHP提供了...
java获取今天、昨天、近一周、近两周、近三周、近一月、近两月、近三月、近半年、本周、上周、本月、上月时间段
Java日期工具类 1、日期的各种格式化 2、获取当前年度 3、获取当前月份 4、获取当前天号数 5、获取当前时间往前推一个月的时间 6、获取上个月("MMM yyyy") 7、获取上个月("yyyymm") 8、获取上个月("yyyy-mm") 9、...
获取本周 上周 本月 上月 本季度的日期!供大家参考!
2. **结合`WEEKDAY`函数**:`WEEKDAY(date, [return_type])`,这个函数返回指定日期是星期几,`return_type`参数可以改变返回值的类型,例如1(星期日是一周的第一天)到7(星期一是一周的第一天)。默认情况下,`...
除了上述几种日期之外,还可以通过类似的逻辑获取到其他日期,例如获取下周一、下周日、本月第一天、上月第一天、下月第一天等等。这些方法的实现逻辑基本一致,主要是通过调整`Calendar`对象中的日期来达到目的。 ...
在C#编程中,有时我们需要获取特定月份的第一天和最后一天日期,比如上个月的日期范围。这在处理数据统计、报表生成或者时间相关的业务逻辑中非常常见。本篇文章将详细解析如何使用C#来获取上个月的第一天和最后一天...
Java日期处理是编程中常见的需求,此代码示例展示了如何在Java中操作日期,包括获取当前日期、本周、本月、本年以及特定日期之间的天数差异。以下是对这些知识点的详细解释: 1. **日期时间类**:Java中的日期时间...