想请教一下,应该怎么怎么做。。
我的想法是,用户选择一年中的第几周,
然后计算出这周开始的日期和结束日期,
根据这个来进行时间段的查询,
可是不知道怎么实现。。请各位大大帮帮忙。。
或者有什么更好的方法也可以。。主要是求出这周的第一天和最后一天的日期。。
先在这里谢谢大家!!!

解决方案 »

  1.   

    太长了分两次发/*  
    Date.prototype.isLeapYear 判断闰年
    Date.prototype.Format 日期格式化
    Date.prototype.DateAdd 日期计算
    Date.prototype.DateDiff 比较日期差
    Date.prototype.toString 日期转字符串
    Date.prototype.toArray 日期分割为数组
    Date.prototype.DatePart 取日期的部分信息
    Date.prototype.MaxDayOfDate 取日期所在月的最大天数
    Date.prototype.WeekNumOfYear 判断日期所在年的第几周
    StringToDate 字符串转日期型
    IsValidDate 验证日期有效性
    CheckDateTime 完整日期时间检查
    daysBetween 日期天数差  将String类型解析为Date类型.  
      parseDate('2006-1-1') return new Date(2006,0,1)  
      parseDate(' 2006-1-1 ') return new Date(2006,0,1)  
      parseDate('2006-1-1 15:14:16') return new Date(2006,0,1,15,14,16)  
      parseDate(' 2006-1-1 15:14:16 ') return new Date(2006,0,1,15,14,16);  
      parseDate('2006-1-1 15:14:16.254') return new Date(2006,0,1,15,14,16,254)  
      parseDate(' 2006-1-1 15:14:16.254 ') return new Date(2006,0,1,15,14,16,254)  
      parseDate('不正确的格式') retrun null  
    */  
    function parseDate(str){   
      if(typeof str == 'string'){   
        var results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) *$/);   
        if(results && results.length>3)   
          return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3]));    
        results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) +(\d{1,2}):(\d{1,2}):(\d{1,2}) *$/);   
        if(results && results.length>6)   
          return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3]),parseInt(results[4]),parseInt(results[5]),parseInt(results[6]));    
        results = str.match(/^ *(\d{4})-(\d{1,2})-(\d{1,2}) +(\d{1,2}):(\d{1,2}):(\d{1,2})\.(\d{1,9}) *$/);   
        if(results && results.length>7)   
          return new Date(parseInt(results[1]),parseInt(results[2]) -1,parseInt(results[3]),parseInt(results[4]),parseInt(results[5]),parseInt(results[6]),parseInt(results[7]));    
      }   
      return null;   

    /*  
    //---------------------------------------------------   
    // 日期格式化   
    // 格式 YYYY/yyyy/YY/yy 表示年份   
    // MM/M 月份   
    // W/w 星期   
    // dd/DD/d/D 日期   
    // hh/HH/h/H 时间   
    // mm/m 分钟   
    // ss/SS/s/S 秒   
    //---------------------------------------------------   
    Date.prototype.Format = function(formatStr)    
    {    
        var str = formatStr;    
        var Week = ['日','一','二','三','四','五','六'];   
       
        str=str.replace(/yyyy|YYYY/,this.getFullYear());    
        str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100));    
       
        str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0' + this.getMonth());    
        str=str.replace(/M/g,this.getMonth());    
       
        str=str.replace(/w|W/g,Week[this.getDay()]);    
       
        str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate());    
        str=str.replace(/d|D/g,this.getDate());    
       
        str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours());    
        str=str.replace(/h|H/g,this.getHours());    
        str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes());    
        str=str.replace(/m/g,this.getMinutes());    
       
        str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds());    
        str=str.replace(/s|S/g,this.getSeconds());    
       
        return str;    
    }    
     *//*
    alert(Date.parseString(new Date().format("MM月dd日yy年"),"MM月dd日yy年"));
    var today = new Date();
    var todayString = today.format("yyyy-MM-dd");
    alert(todayString);
    var parsedDate = Date.parseString(todayString);
    alert(parsedDate);
    */Date.prototype.format = function(formatter)
    {
        if(!formatter || formatter == "")
        {
            formatter = "yyyy-MM-dd";
        }
        var year = this.getYear().toString();
        var month = (this.getMonth() + 1).toString();
        var day = this.getDate().toString();
        var yearMarker = formatter.replace(/[^y|Y]/g,'');
        if(yearMarker.length == 2)
        {
            year = year.substring(2,4);
        }    
        var monthMarker = formatter.replace(/[^m|M]/g,'');
        if(monthMarker.length > 1)
        {
            if(month.length == 1) 
            {
                month = "0" + month;
            }
        }    
        var dayMarker = formatter.replace(/[^d]/g,'');
        if(dayMarker.length > 1)
        {
            if(day.length == 1) 
            {
                day = "0" + day;
            }
        }    
        return formatter.replace(yearMarker,year).replace(monthMarker,month).replace(dayMarker,day);    
    }Date.parseString = function(dateString,formatter)
    {
        var today = new Date();
        if(!dateString || dateString == "")
        {
            return today;
        }
        if(!formatter || formatter == "")
        {
            formatter = "yyyy-MM-dd";
        }  
        var yearMarker = formatter.replace(/[^y|Y]/g,'');   
        var monthMarker = formatter.replace(/[^m|M]/g,'');   
        var dayMarker = formatter.replace(/[^d]/g,'');
        var yearPosition = formatter.indexOf(yearMarker);
        var yearLength = yearMarker.length;
        var year =  dateString.substring(yearPosition ,yearPosition + yearLength) * 1;
        if( yearLength == 2)
        {
            if(year < 50 )
            {
                year += 2000;
            }
            else
            {
                year += 1900;
            }
        }
        var monthPosition = formatter.indexOf(monthMarker);
        var month = dateString.substring(monthPosition,monthPosition + monthMarker.length) * 1 - 1;
        var dayPosition = formatter.indexOf(dayMarker);
        var day = dateString.substring( dayPosition,dayPosition + dayMarker.length )* 1;
        return new Date(year,month,day);
    }
      

  2.   


    //---------------------------------------------------   
    // 判断闰年   
    //---------------------------------------------------   
    Date.prototype.isLeapYear = function()    
    {    
        return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));    
    }    
       
     
    //+---------------------------------------------------   
    //| 求两个时间的天数差 日期格式为 YYYY-MM-dd    
    //+---------------------------------------------------   
    function daysBetween(DateOne,DateTwo)   
    {    
        var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-'));   
        var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);   
        var OneYear = DateOne.substring(0,DateOne.indexOf ('-'));   
       
        var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-'));   
        var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);   
        var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-'));   
       
        var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);    
        return Math.abs(cha);   
    }   
       
       
    //+---------------------------------------------------   
    //| 日期计算   
    //+---------------------------------------------------   
    Date.prototype.DateAdd = function(strInterval, Number) {    
        var dtTmp = this;   
        switch (strInterval) {    
            case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number));   
            case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number));   
            case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number));   
            case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number));   
            case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number));   
            case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());   
            case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());   
            case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());   
        }   
    }   
       
    //+---------------------------------------------------   
    //| 比较日期差 dtEnd 格式为日期型或者 有效日期格式字符串   
    //+---------------------------------------------------   
    Date.prototype.DateDiff = function(strInterval, dtEnd) {    
        var dtStart = this;   
        if (typeof dtEnd == 'string' )//如果是字符串转换为日期型   
        {    
            dtEnd = StringToDate(dtEnd);   
        }   
        switch (strInterval) {    
            case 's' :return parseInt((dtEnd - dtStart) / 1000);   
            case 'n' :return parseInt((dtEnd - dtStart) / 60000);   
            case 'h' :return parseInt((dtEnd - dtStart) / 3600000);   
            case 'd' :return parseInt((dtEnd - dtStart) / 86400000);   
            case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7));   
            case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1);   
            case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear();   
        }   
    }   
       
    //+---------------------------------------------------   
    //| 日期输出字符串,重载了系统的toString方法   
    //+---------------------------------------------------   
    Date.prototype.toString = function(showWeek)   
    {    
        var myDate= this;   
        var str = myDate.toLocaleDateString();   
        if (showWeek)   
        {    
            var Week = ['日','一','二','三','四','五','六'];   
            str += ' 星期' + Week[myDate.getDay()];   
        }   
        return str;   
    }   
       
    //+---------------------------------------------------   
    //| 日期合法性验证   
    //| 格式为:YYYY-MM-DD或YYYY/MM/DD   
    //+---------------------------------------------------   
    function IsValidDate(DateStr)    
    {    
        var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格;    
        if(sDate=='') return true;    
        //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为''    
        //数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式    
        var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2 }[\-/]{ 1 }[\d]{ 1,2 }/g,'');    
        if (s=='') //说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D    
        {    
            var t=new Date(sDate.replace(/\-/g,'/'));    
            var ar = sDate.split(/[-/:]/);    
            if(ar[0] != t.getYear() || ar[1] != t.getMonth()+1 || ar[2] != t.getDate())    
            {    
                //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');    
                return false;    
            }    
        }    
        else    
        {    
            //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');    
            return false;    
        }    
        return true;    
    }    
       
    //+---------------------------------------------------   
    //| 日期时间检查   
    //| 格式为:YYYY-MM-DD HH:MM:SS   
    //+---------------------------------------------------   
    function CheckDateTime(str)   
    {    
        var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2 }):(\d{ 1,2 }):(\d{ 1,2 })$/;    
        var r = str.match(reg);    
        if(r==null)return false;    
        r[2]=r[2]-1;    
        var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);    
        if(d.getFullYear()!=r[1])return false;    
        if(d.getMonth()!=r[2])return false;    
        if(d.getDate()!=r[3])return false;    
        if(d.getHours()!=r[4])return false;    
        if(d.getMinutes()!=r[5])return false;    
        if(d.getSeconds()!=r[6])return false;    
        return true;    
    }    
       
    //+---------------------------------------------------   
    //| 把日期分割成数组   
    //+---------------------------------------------------   
    Date.prototype.toArray = function()   
    {    
        var myDate = this;   
        var myArray = Array();   
        myArray[0] = myDate.getFullYear();   
        myArray[1] = myDate.getMonth();   
        myArray[2] = myDate.getDate();   
        myArray[3] = myDate.getHours();   
        myArray[4] = myDate.getMinutes();   
        myArray[5] = myDate.getSeconds();   
        return myArray;   
    }   
       
    //+---------------------------------------------------   
    //| 取得日期数据信息   
    //| 参数 interval 表示数据类型   
    //| y 年 m月 d日 w星期 ww周 h时 n分 s秒   
    //+---------------------------------------------------   
    Date.prototype.DatePart = function(interval)   
    {    
        var myDate = this;   
        var partStr='';   
        var Week = ['日','一','二','三','四','五','六'];   
        switch (interval)   
        {    
            case 'y' :partStr = myDate.getFullYear();break;   
            case 'm' :partStr = myDate.getMonth()+1;break;   
            case 'd' :partStr = myDate.getDate();break;   
            case 'w' :partStr = Week[myDate.getDay()];break;   
            case 'ww' :partStr = myDate.WeekNumOfYear();break;   
            case 'h' :partStr = myDate.getHours();break;   
            case 'n' :partStr = myDate.getMinutes();break;   
            case 's' :partStr = myDate.getSeconds();break;   
        }   
        return partStr;   
    }   
       
    //+---------------------------------------------------   
    //| 取得当前日期所在月的最大天数   
    //+---------------------------------------------------   
    Date.prototype.MaxDayOfDate = function()   
    {    
        var myDate = this;   
        var ary = myDate.toArray();   
        var date1 = (new Date(ary[0],ary[1]+1,1));   
        var date2 = date1.dateAdd(1,'m',1);   
        var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));   
        return result;   
    }
      

  3.   

    有没有C#的代码??
    JS的代码不太会用..不过先谢谢楼上这位兄弟的热心!!!
    开贴的时候分数给的太少..过了今晚我还会加分的
      

  4.   

    可以利用SQL里面的方法拼装一下组成你需要的
      

  5.   

    先确定一年是多少天,比如是365天,那就是1-365个ID,以这个ID为主键。用365除以7得出有多少周,某一周就是在其中的一段,比如ID为1-7,8-15等,然后去求出日期所对应的ID为多少,比如1月1日为1,1月7日为7.。这样根据ID形成一一对应的关系。代码你自己实现把,我是以前用PHP做的,思路也是自己想的。
      

  6.   

    我用PHP写的时候用了2个函数,1个就是传递周的代号,然后函数返回出其起始ID和末尾ID,第二个就是传入起始ID和末尾ID然后返回起始日期和结束日期
      

  7.   

    非常简单...一周七天...地球人都知道...
    int year = 2008;
    int weeks = 3;
    DateTime start = new DateTime(year, 1, 1);
    DateTime first = start.AddDays((weeks - 1) * 7 - (int)start.DayOfWeek);
    DateTime last = first.AddDays(7).AddSeconds(-1);
    问题是...规则...1.一周的第一天是按星期日还是星期一算?(国际标准是星期日...可总有BT的需求不是吗)
    2.一年的一周从1月1日算起还是包含1月1日的这周第一天?
    3.一年的最后一周到该年最后一天截止还是包含下一年的天数(如果这两天不是同一天)?所以你必须先清楚地定义规则...
      

  8.   

    刚查了一下...国际标准周首日是星期一...BT的是微软(它一贯不把别家的标准放在眼里)...呵呵年首周是第一个在指定的周首日前包含四天或更多天的周...在.NET中由枚举System.Globalization.CalendarWeekRule定义...FirstDay 指示年的第一周从该年的第一天开始,到所指定周的下一个首日前结束。值为 0。FirstFullWeek 指示年的第一周从所指定周首日的第一个匹配项开始,可以是年的第一天或其后某一天。值为 1。FirstFourDayWeek 指示年的第一周是第一个在指定的周首日前包含四天或更多天的周。符合 ISO 8601。值为 2。//这个是国际标准...
      

  9.   

    这种需求我以后也可能用得到...写了个完整的通用方法...权当饭后活动一下...自己去blog看吧...http://blog.csdn.net/vrhero/archive/2008/01/13/2042481.aspx
      

  10.   

    根据当前日期计算出当前周一到周日的日期,并绑定到多选框中,checkboxlist
               name 显示周一,value显示为2011-09-12           DateTime dt = DateTime.Now; //当前时间
                DateTime startWeek = dt.AddDays(1 - Convert.ToInt32(dt.DayOfWeek.ToString("d"))); //本周周一
                DateTime endWeek = startWeek.AddDays(6); //本周周日
                while (startWeek < endWeek)
                {
                    cblWorkingDays.Items.Add(new ListItem("周" + "日一二三四五六".Substring((int)startWeek.DayOfWeek, 1), startWeek.ToString("yyyy-MM-dd")));
                    startWeek = startWeek.AddDays(1);
                }          //周日放在第一个
                cblWorkingDays.Items.Insert(0, new ListItem("周日",endWeek.ToString("yyyy-MM-dd")));
    http://www.notsee.info/tech/net/net-detail-447.xml
      

  11.   

    指定周次求该周的第一天日期
    /// <summary>
            /// 指定周次求该周的第一天日期
            /// </summary>
            /// <param name="curDatePart">周次</param>
            /// <param name="curYear">年份</param>
            /// <param name="daystart">1表示从第一个周日开始计算,其他表示默认</param>
            /// <returns>该周的第一天日期</returns>
            public string GetFirstDayOfWeekInYear(int curDatePart, int curYear, int daystart)
            {
                int weeks = curDatePart;
                const int DAYS_IN_WEEK = 7;
                int oneorzero;
                if (daystart == 1)
                {
                    oneorzero = 0;
                }
                else
                {
                    oneorzero = 1;
                }
                DateTime dt = new DateTime(curYear, 1, 1).AddDays((weeks - oneorzero) * DAYS_IN_WEEK);
                string dw = dt.AddDays(0 - (int)dt.DayOfWeek).ToShortDateString();
                return dw;
            }http://www.notsee.info/tech/net/net-detail-450.xml