次のコードを実装する簡単な方法はありますか? このように書くのは複雑すぎると思いますか?
初心者なので助けてください。
<?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 され、最終的にすべてのデータが格納されます。出力。
それとも、それを実装する他の簡単な方法はありますか?データベースへの負荷とプログラムの実行速度を考慮する必要があります。
再帰を使用します。 。 。
データベースから 1 週間のデータを取得する場合
次に、 $r['date'] が時間データを取得すると仮定すると、
$c = array(0,0,0,0,0,0,0 ); //ループ内
$c[date('w', $r['date'])]++;
$c は毎日のカウントです
1 月のデータをデータベースから取得した場合
次に、 $r['date'] は時刻データを取得し、その後
$c = array_fill(1, 31, 0)
//ループ内
$c[date('d', $r ['date']); ]++;
$c は 1 日あたりのカウント数です
何をしたいのかわかりません
何が必要なのか説明していただけますか?
今週のすべてのデータをデータベースから取得し、毎日が何個であるかを判断しました。たとえば、今日は木曜日で、月曜日から木曜日までのデータをデータベースから取得しました。月曜日と火曜日の数値、水曜日はいくら、木曜日はいくら、今日が日曜日の場合は、今週のすべてのデータを取得し、月曜日、火曜日、水曜日、木曜日などの数値をそれぞれ取得します。将来的には、毎日取得できる月数に拡張される予定です。
上記のプログラムの意味は
まず、データベースからクエリされたすべてのデータを取得します。その後、各日の初期値は 0 になります。時刻になるとループデータに if 判定が入り、その時刻が何日であるかが判断され、対応する日数が +1 され、最終的にすべてのデータが格納されます。出力。
それとも、他にもっと簡単な実装方法はありますか?データベースへの負荷とプログラムの実行速度を考慮する必要があります。
対応する日数を追加するだけの場合は、非常に簡単です。
配列に直接保存するだけです。
曜日ごとに追加する場合は、非常に簡単です。
配列 $days を直接使用します。 =array(0,0 ,0,0,0,0,0);//date('w', $r['date']) によると、次のような数値の曜日: "0" (日曜日) を "6" (土曜日) に変換し、配列を取得します
この方法では、毎回
$days[date('w', your date)]++ のみが必要となり、判断を省略できます
月次の場合、配列の添字 1 ~ 31 で配列を定義し、初期値はすべて 0、その他は週と同じになります
データベースからその週のデータを取得する場合
$c = array(0,0,0,0,0,0,0) です
//ループ内
$c[date('w ', $r[' date'])]++;
$c は 1 日あたりのカウント数です
データベースから 1 月のデータを取得する場合
次に、$r['date'] が時刻データを取得すると仮定すると、 then
$c = array_fill(1, 31, 0);
//ループ内
$c[date('d', $r['date'])]++; $c はカウント数です一日あたり
ありがとう、解決しました。6階のチンモモデレーターも同じ考えです。ありがとうございます。