Heim >Backend-Entwicklung >PHP-Tutorial >下面这些代码能不能简写啊?

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

WBOY
WBOYOriginal
2016-06-23 14:39:531088Durchsuche

下面这段代码有没有简单办法实现啊,我觉得这样写太复杂了,如果写一个月的数据,岂不是需要写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版主也是这个思路,真是英雄所见略同,谢谢!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn