2016-01-24 92 views
1

我在下面的php文件中有这段代码。 问题是我得到超过120秒的错误最大执行时间。我无法弄清楚这个问题,但我认为这可能与我做循环的方式有关。如果我这样做的方式不好,请提前谅解。PHP循环最大执行时间

<?php 

for ($i=0;$i<168;$i++) { 
    $answers[$i] = (int)$data[6+$i]; 
} 

$A = $B = $C = $D = $E = $F = $G = $H = $I = $J = $K = $L = $M = $N = 0; 

for ($z=0;$z<168;$z+14) { 
    $A = $A + $answers[0+$z]; 
    $B = $B + $answers[1+$z]; 
    $C = $C + $answers[2+$z]; 
    $D = $D + $answers[3+$z]; 
    $E = $E + $answers[4+$z]; 
    $F = $F + $answers[5+$z]; 
    $G = $G + $answers[6+$z]; 
    $H = $H + $answers[7+$z]; 
    $I = $I + $answers[8+$z]; 
    $J = $J + $answers[9+$z]; 
    $K = $K + $answers[10+$z]; 
    $L = $L + $answers[11+$z]; 
    $M = $M + $answers[12+$z]; 
    $N = $N + $answers[13+$z]; 
} 

echo "<table border='1'>"; 
echo "<tr><td>A</td><td>" . $A . "</td></tr>"; 
echo "<tr><td>B</td><td>" . $B . "</td></tr>"; 
echo "<tr><td>C</td><td>" . $C . "</td></tr>"; 
echo "<tr><td>D</td><td>" . $D . "</td></tr>"; 
echo "<tr><td>E</td><td>" . $E . "</td></tr>"; 
echo "<tr><td>F</td><td>" . $F . "</td></tr>"; 
echo "<tr><td>G</td><td>" . $G . "</td></tr>"; 
echo "<tr><td>H</td><td>" . $H . "</td></tr>"; 
echo "<tr><td>I</td><td>" . $I . "</td></tr>"; 
echo "<tr><td>J</td><td>" . $J . "</td></tr>"; 
echo "<tr><td>K</td><td>" . $K . "</td></tr>"; 
echo "<tr><td>L</td><td>" . $L . "</td></tr>"; 
echo "<tr><td>M</td><td>" . $M . "</td></tr>"; 
echo "<tr><td>N</td><td>" . $N . "</td></tr>"; 
echo "</table>"; 
echo "<br>"; 
+0

增加超时或禁用此代码 - '的set_time_limit(240)'或'的set_time_limit (0)'〜其中'0'表示没有限制 – RamRaider

+0

所以这意味着我真的必须等待它完成?没有办法让它加载“即时”? :( – rekt

回答

4

这个循环是不实际递增:

for ($z=0; $z<168; $z+14) { 

应该是:

for ($z=0; $z<168; $z+=14) { 

$z+14实际上不会增加​​$z

+0

噢,对了!感谢您指出:) :)在几分钟内接受答案,因为它说我必须等5分钟:P谢谢:) – rekt

2

除了已经提供的答案,从而能够解决的核心问题,你的代码可以大大简化,如果重复获得汇总(而不是测试,而是应该把你在正确的轨道上):

$totalCount = 168; 
    $batchSize = 14; 

    for($i=0;$i<168;$i++){ 
     $answers[$i] = (int)$data[6+$i]; 
    } 

    $buffer = array(); 
    for ($i = 0; $i < $batchSize; $i ++) 
    $buffer[$i] = 0; 

    for ($z=0; $z<168; $z += $batchSize) { 
     for ($i = 0; $i < $batchSize; $i ++) { 
      $buffer[$i] += $answers[$i + $z] 
     } 
    } 

    echo "<table border='1'>"; 
    for ($i = 0; $i < $batchSize; $i ++) { 
     $colName = chr(65 + $i);    // A has code 65 
     echo "<tr><td>$colName</td><td>" . $buffer[$i] . "</td></tr>"; 
    } 
    echo "</table>"; 
    echo "<br>"; 

这将允许改变问题数量和/或批量在未来很容易计算(除非你超越Z,这就需要改变chr逻辑)

+0

我会检查这一点,非常感谢: ) – rekt