首页 >后端开发 >php教程 >下面这些代码能不能简写啊?

下面这些代码能不能简写啊?

WBOY
WBOY原创
2016-06-23 14:39:531088浏览

下面这段代码有没有简单办法实现啊,我觉得这样写太复杂了,如果写一个月的数据,岂不是需要写30个case
求大侠帮忙,俺是新手

<?phpdate_default_timezone_set('PRC');$c1=0;$c2=0;$c3=0;$c4=0;$c5=0;$c6=0;$c7=0;$w = date("w",time());switch($w){	case 1: 				break; 	case 2:	    $t1=strtotime(date("Y-m-d")." 23:59:59");//周二		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif(1387420136<=$t2){			$c2 += 1;		}		echo $c1;		break; 	case 3:	    $t1=strtotime(date("Y-m-d")." 23:59:59");//周三		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周二		$t3=strtotime(date("Y-m-d",strtotime("-2 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif($t3<1387420136&&1387420136<=$t2){			$c2 += 1;		}elseif(1387420136<=$t3){			$c3 += 1;		}		echo $c1;				break; 	case 4:	    $t1=strtotime(date("Y-m-d")." 23:59:59");//周四		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周三		$t3=strtotime(date("Y-m-d",strtotime("-2 day"))." 23:59:59");//周二		$t4=strtotime(date("Y-m-d",strtotime("-3 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif($t3<1387420136&&1387420136<=$t2){			$c2 += 1;		}elseif($t4<1387420136&&1387420136<=$t3){			$c3 += 1;		}elseif(1387420136<=$t4){			$c4 += 1;		}		echo $c1;		break; 	case 5:		$t1=strtotime(date("Y-m-d")." 23:59:59");//周五		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周四		$t3=strtotime(date("Y-m-d",strtotime("-2 day"))." 23:59:59");//周三		$t4=strtotime(date("Y-m-d",strtotime("-3 day"))." 23:59:59");//周二		$t5=strtotime(date("Y-m-d",strtotime("-4 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif($t3<1387420136&&1387420136<=$t2){			$c2 += 1;		}elseif($t4<1387420136&&1387420136<=$t3){			$c3 += 1;		}elseif($t5<1387420136&&1387420136<=$t4){			$c4 += 1;		}elseif(1387420136<=$t5){			$c5 += 1;		}		echo $c1;		break; 	case 6:		$t1=strtotime(date("Y-m-d")." 23:59:59");//周六		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周五		$t3=strtotime(date("Y-m-d",strtotime("-2 day"))." 23:59:59");//周四		$t4=strtotime(date("Y-m-d",strtotime("-3 day"))." 23:59:59");//周三		$t5=strtotime(date("Y-m-d",strtotime("-4 day"))." 23:59:59");//周二		$t6=strtotime(date("Y-m-d",strtotime("-5 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif($t3<1387420136&&1387420136<=$t2){			$c2 += 1;		}elseif($t4<1387420136&&1387420136<=$t3){			$c3 += 1;		}elseif($t5<1387420136&&1387420136<=$t4){			$c4 += 1;		}elseif($t6<1387420136&&1387420136<=$t5){			$c5 += 1;		}elseif(1387420136<=$t6){			$c6 += 1;		}		echo $c1;		break; 	case 7:	    $t1=strtotime(date("Y-m-d")." 23:59:59");//周日		$t2=strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");//周六		$t3=strtotime(date("Y-m-d",strtotime("-2 day"))." 23:59:59");//周五		$t4=strtotime(date("Y-m-d",strtotime("-3 day"))." 23:59:59");//周四		$t5=strtotime(date("Y-m-d",strtotime("-4 day"))." 23:59:59");//周三		$t6=strtotime(date("Y-m-d",strtotime("-5 day"))." 23:59:59");//周二		$t7=strtotime(date("Y-m-d",strtotime("-6 day"))." 23:59:59");//周一		if($t2<1387420136&&1387420136<=$t1){			$c1 += 1;		}elseif($t3<1387420136&&1387420136<=$t2){			$c2 += 1;		}elseif($t4<1387420136&&1387420136<=$t3){			$c3 += 1;		}elseif($t5<1387420136&&1387420136<=$t4){			$c4 += 1;		}elseif($t6<1387420136&&1387420136<=$t5){			$c5 += 1;		}elseif($t7<1387420136&&1387420136<=$t6){			$c6 += 1;		}elseif(1387420136<=$t7){			$c7 += 1;		}		echo $c1;		break;	default:;			    }?>


回复讨论(解决方案)

看不出来你想要做什么
能不能说明一下你的需求是什么?

看不出来你想要做什么
能不能说明一下你的需求是什么?
我从数据库里面得到了本周所有的数据,然后分别判断每天是多少条,比如今天是周四,我从数据库中得到的是周一到周四的数据,然后分别得到周一多少数据,周二多少,周三多少,周四多少,如果今天是周日,我得到了本周所有的数据,然后分别得到周一周二周三周四等是多少。以后还要扩展到月,得到每天的。
我上面的程序的意思是
先得到所有的从数据库中查询出来的数据。然后初始每天的数量是0,到时候if判断放到循环数据里面,分别判断时间属于哪天,然后相应的天的数量+1,最后把所有的数据输出即可。
或者请问还有别的简单点的实现办法吗?需要考虑进数据库的压力和程序执行速度。

用递归。。。

如果你从数据库得到的是一周的数据
那么,设 $r['date'] 取回的时间数据,则有
$c = array(0,0,0,0,0,0,0);
//循环中
$c[date('w', $r['date'])]++;
$c 中就是每天的计数量

如果你从数据库得到的是一月的数据
那么,设 $r['date'] 取回的时间数据,则有
$c = array_fill(1, 31, 0);
//循环中
$c[date('d', $r['date'])]++;
$c 中就是每天的计数量




看不出来你想要做什么
能不能说明一下你的需求是什么?
我从数据库里面得到了本周所有的数据,然后分别判断每天是多少条,比如今天是周四,我从数据库中得到的是周一到周四的数据,然后分别得到周一多少数据,周二多少,周三多少,周四多少,如果今天是周日,我得到了本周所有的数据,然后分别得到周一周二周三周四等是多少。以后还要扩展到月,得到每天的。
我上面的程序的意思是
先得到所有的从数据库中查询出来的数据。然后初始每天的数量是0,到时候if判断放到循环数据里面,分别判断时间属于哪天,然后相应的天的数量+1,最后把所有的数据输出即可。
或者请问还有别的简单点的实现办法吗?需要考虑进数据库的压力和程序执行速度。
如果只是增加相应的天是数量的话,这个很简单吧
直接用数组保存就可以了
如果你是按星期几来增加的话,这个很简单:
直接用数组$days=array(0,0,0,0,0,0,0);//根据date('w', $r['date']) - 数字型的星期几,如: "0" (星期日) 至 "6" (星期六)  而得出的一个数组

这样
你每次只需要
$days[date('w', 你的日期)]++; 就可以省略你判断了

如果你是按月的话,那么你定义个数组下标是1-31的数组,初始值都是0的数组,其他的就跟周的一样了

如果你从数据库得到的是一周的数据
那么,设 $r['date'] 取回的时间数据,则有
$c = array(0,0,0,0,0,0,0);
//循环中
$c[date('w', $r['date'])]++;
$c 中就是每天的计数量

如果你从数据库得到的是一月的数据
那么,设 $r['date'] 取回的时间数据,则有
$c = array_fill(1, 31, 0);
//循环中
$c[date('d', $r['date'])]++;
$c 中就是每天的计数量
谢谢,已经解决了,6楼的chinmo版主也是这个思路,真是英雄所见略同,谢谢!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn