如何从数组中创建多维数组并执行过滤?

时间:2013-08-28 11:16:35

标签: php multidimensional-array

我的目标是将所有数组值保存在另一个数组中,但我不知道该怎么做。 这是我的简单数组:

$grand_total = $total + $cost;
$cost_ratio = ($cost/$grand_total) * 100;
$paid_ratio = ($total/$grand_total) * 100;

$info[] = array(
             'id' => $data['id'],
             'ratio' => $cost_ratio,
             'status' => $status 
          );

这是我的示例数组输出

Array
(
[0] => Array
    (
        [id] => 53
        [ratio] => 100
        [status] => C
    )

[1] => Array
    (
        [id] => 57
        [ratio] => 100
        [status] => I
    )

[2] => Array
    (
        [id] => 60
        [ratio] => 1.3157894736842
        [status] => I
    )

创建数组之后,接下来要做的就是通过获取比率来过滤它。 如上所示,我有一个变量$cost_ratio,这个变量将过滤我的数组。

这是我的代码的延续:

 //declare a variable
 $var1 = 0;
 $var2 = 0;
 $var3 = 0;
 $var4 = 0;
 $var5 = 0;
 $var6 = 0;
 $var7 = 0;
 $var8 = 0;
 $var9 = 0;
 $var10 = 0;

之后

  for($x = 0; $x < sizeof($info); $x++){

            $status_info = $info[$x]['status'];
            $temp = $info[$x]['ratio'];

            /*this will set my filter*/

            /*if temp <= 9, i need to put all of my array that has a ratio <= 9*/

            if($temp <= 9){
                $var1++;
            }else if($temp <= 19){
                $var2++;
            }else if($temp <= 29){
                $var3++;
            }else if($temp <= 39){
                $var4++;
            }else if($temp <= 49){
                $var5++;
            }else if($temp <= 59){
                $var6++;
            }else if($temp <= 69){
                $var7++;
            }else if($temp <= 79){
                $var8++;
            }else if($temp <= 89){
                $var9++;
            }else{
                $var10++;
            }

      }

最后是用于显示我的记录的表

  echo "<table border='1'>";

        echo "<tr>";
            echo "<td>PERCENTAGE RANGE</td>";
            echo "<td>VOLUME</td>";
            echo "<td>RATIO</td>";
            echo "<td>BACKORDERED</td>";
            echo "<td>CANCELED</td>";
            echo "<td>COD APPROVED</td>";
            echo "<td>COD PENDING</td>";
            echo "<td>COD SHIPPED</td>";
            echo "<td>COMPLETED</td>";
            echo "<td>DECLINED</td>";
            echo "<td>FAILED</td>";
            echo "<td>FRAUD CHECKING</td>";
            echo "<td>PAID & WAITING SHIPPING</td>";
            echo "<td>PENDING</td>";
            echo "<td>SHIPPED</td>";
            echo "<td>TEST</td>";
            echo "<td>WAITING FOR APPROVAL</td>";
            echo "<td>WAITING PAYMENT</td>";
        echo "</tr>";

        echo "<tr>";
            echo "<td>10% - 90%</td>";
            echo "<td>".$var1."</td>"; <!-- IF ratio has a value between 1 - 9 go here -->
            echo "<td></td>";
            echo "<td>".$x1."</td>";
            echo "<td>".$x2."</td>";
            echo "<td>".$x3."</td>";
            echo "<td>".$x4."</td>";
            echo "<td>".$x5."</td>";
            echo "<td>".$x6."</td>";
            echo "<td>".$x7."</td>";
            echo "<td>".$x8."</td>";
            echo "<td>".$x9."</td>";
            echo "<td>".$x10."</td>";
            echo "<td>".$x11."</td>";
            echo "<td>".$x12."</td>";
            echo "<td>".$x13."</td>";
            echo "<td>".$x14."</td>";
            echo "<td>".$x15."</td>";          
        echo "</tr>";

        echo "<tr>";
            echo "<td>20% - 80%</td>"; <!-- IF ratio has a value between 10 - 19 go here -->
            echo "<td>".$var2."</td>";
            echo "<td></td>";
            echo "<td>".$x1."</td>";
            echo "<td>".$x2."</td>";
            echo "<td>".$x3."</td>";
            echo "<td>".$x4."</td>";
            echo "<td>".$x5."</td>";
            echo "<td>".$x6."</td>";
            echo "<td>".$x7."</td>";
            echo "<td>".$x8."</td>";
            echo "<td>".$x9."</td>";
            echo "<td>".$x10."</td>";
            echo "<td>".$x11."</td>";
            echo "<td>".$x12."</td>";
            echo "<td>".$x13."</td>";
            echo "<td>".$x14."</td>";
            echo "<td>".$x15."</td>";          
        echo "</tr>";
 .
 .

这就是我想要做的事情:

[ratio between 1 - 9 value] = array(
     [0] = array(
              'id' => 1,
              'status' => 'C'
           ),
     [1] = array(
              'id' => 3,
              'status' => 'D'
           ),
     [2] = array(
              'id' => 6,
              'status' => 'J'
           ),

),

[ratio between 10 - 19 value] = array(
     [0] = array(
              'id' => 1,
              'status' => 'C'
           ),
     [1] = array(
              'id' => 3,
              'status' => 'D'
           ),
     [2] = array(
              'id' => 6,
              'status' => 'J'
           ),

),
.
.
.

这就是我想做的事情,但我很难做到这一点。

1 个答案:

答案 0 :(得分:1)

您可以通过执行以下操作轻松对数组进行分组:

$array = array(
    array( 'id' => 53, 'ratio' => 100, 'status' => 'I'),
    array( 'id' => 54, 'ratio' => 50, 'status' => 'C'),
    array( 'id' => 56, 'ratio' => 42, 'status' => 'D')
);

// Grouping array by ratio
$group = array();
foreach($array as $value) {
    $groupIndex = min($value['ratio'] / 10, 9);
    $group[$groupIndex][] = $value;
}

var_dump($group);

以下是示例输出

array (size=3)
  9 => 
    array (size=1)
      0 => 
        array (size=3)
          'id' => int 53
          'ratio' => int 100
          'status' => string 'I' (length=1)
  5 => 
    array (size=1)
      0 => 
        array (size=3)
          'id' => int 54
          'ratio' => int 50
          'status' => string 'C' (length=1)
  4 => 
    array (size=1)
      0 => 
        array (size=3)
          'id' => int 56
          'ratio' => int 42
          'status' => string 'D' (length=1)

注意到索引9表示从90 +,5表示从50到59,4表示从40到49.如果您对索引约定感到困惑,这里是完整列表:

$group[0]   <--- from 0 to 9
$group[1]   <--- from 10 to 19
$group[2]   <--- from 20 to 29
$group[3]   <--- from 30 to 39
$group[4]   <--- from 40 to 49
$group[5]   <--- from 50 to 59
$group[6]   <--- from 60 to 69
$group[7]   <--- from 70 to 79
$group[8]   <--- from 80 to 89
$group[9]   <--- from 90+