其实是要精确到周即可, 即给定当前时间, 知道是本学期的开学第几周. 问题的关键好像是没找到规律, 我现在用的是如下代码(php), 准确度不够好:
function teachweek ($date){
$timestamp=strtotime($date);
if (date('m', $timestamp)>=9){
return date('W', $timestamp)-35;
}elseif(date('m', $timestamp)<=2){
return date('W', $timestamp)+18;
}else{
return date('W', $timestamp)-7;
}
}
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
不准确的问题应该出在35、18这几个数字上,另外,如果9月1日是星期六或者星期日的话,也不能算作第一周,所以,可以先判断当年9月1日是在第几周
这样,第四行就能替换成
是否+1需要通过对9月1日是否为周六/日判断确定,这儿具体就不写了;
如果日期是年初寒假之前,还需要跨年计算去年9月1日到12月31日的周数
同样的,是否+1需要通过对9月1日是否为周六/日判断确定,这样,第六行就能替换成
同理,确定第二学期开学日期的话,类似思路修改最后一个retrun里的7,即可判断日期是第二学期的第几周
你们都被表面需求迷惑了,如果是问当前日期是开学日期的第几个月,楼主和一楼的逻辑虽然不完全对但是修改一下还是OK的,可是对于第几周就没必要了,因为问题的关键在于7天是一周。我的伪码如下
$weekNumber就是你要的了
感谢大家的贡献. 我觉得可以从下面的表格作出分析(#注):
通过分析发现, 也许我们可以先分析什么时候过年, 然后暑假由过年前后各两周决定, 这里还需要些细化, 例如还和过年是星期几有关.
秋季开学由离9/1号最近的周一决定?
春季由开学日期(由过年决定)?
(#注: 统计结果可能不是非常正确, 大家可以复查.)
这东西还需要用算法做,或者算法能做出来么?直接把校历的时间录到数据库里就完了么
校历出一次管一年,也就是说1年录一次就可以,说白了,根本就没有规律,这个是教务处说了算的
真以为全国高校都9月1号开学 过年都让过元宵节啊 我在某985高校从来就没有在家过完元宵过
我也研究了下我的答案是
ceil(strtotime('now')-strtotime($term_start_date)/7/60/60/24)+1;
用这种 date('W',strtotime("1 September $thisyear"));的话会遭遇跨年的问题