如何从我的数组 php 中过滤数据


How can I filter data from my array php?

我真的很努力过滤我的数据。我知道如何访问数组的某些部分,但正在为如何过滤而苦苦挣扎。我知道如何在SQL SUM和计数中做到这一点,但当涉及到PHP数组时,请提供帮助。

我需要过滤存储在变量$res中的一些数据。

我需要查看每个"REF"出现多少次,每个 ref 的总"LCL_D_CBM",其中"TERR"等于"TERR1"。

foreach ($res as $res1){

   if ($res1["TERR"] == "TERR1"){
   //the individual ref 
   //$res1['REF'];  

   // the coutn of how many times each ref appears
   //echo count($res1['REF']);
   //sum
   //echo array_sum($res1['LCL_D_CBM']);    

   }
}

需要结果像——

中航

3

2561

持续进修基金

456

135

var_dump($res); gives me below
array(350) { 
  
[0]=> array(7) { [0]=> string(3) "CEA" ["REF"]=> string(3) "CEA" [1]=> string(5) "1.080" ["LCL_D_CBM"]=> string(5) "1.080" [2]=> string(3) "WF2" ["AREA_CODE"]=> string(3) "WF2" ["TERR"]=> string(5) "TERR1" } 
            
[1]=> array(7) { [0]=> string(3) "CEA" ["REF"]=> string(3) "CEA" [1]=> string(5) "2.000" ["LCL_D_CBM"]=> string(5) "2.000" [2]=> string(4) "HU13" ["AREA_CODE"]=> string(4) "HU13" ["TERR"]=> string(5) "TERR1" } 
            
[2]=> array(7) { [0]=> string(3) "CEF" ["REF"]=> string(3) "CEA" [1]=> string(5) "2.448" ["LCL_D_CBM"]=> string(5) "2.448" [2]=> string(4) "TW16" ["AREA_CODE"]=> string(4) "TW16" ["TERR"]=> string(5) "TERR2" } ..... etc

你可以

这样解决它。不是一个漂亮的解决方案,但应该完成工作。(我没有测试这个,所以它可能包含拼写错误或其他东西):

$sum_lcl = 0;
$unique_refs = array();
foreach ($res as $res1){
    if (!array_key_exists($res1['REF'], $unique_refs)) {
        $unique_refs[$res1['REF']] = array();
    }   
    $unique_refs[$res1['REF']]['SUM'] = ( array_key_exists('SUM', $unique_refs[$res1['REF']]) ) ? ( intval( $unique_refs[$res1['REF']]['SUM'] ) + 1 ) : 1;
    $unique_refs[$res1['REF']]['LCL_SUM'] = ( array_key_exists('LCL_SUM', $unique_refs[$res1['REF']]) ) ? ( floatval( $unique_refs[$res1['REF']]['LCL_SUM'] ) + floatval( $res1['LCL_D_CBM'] ) ) : 1;

}

foreach( $unique_refs AS $unique => $data ){
    $title = $unique;
    $sum = $data['SUM'];
    $lcl_sum = $data['LCL_SUM'];
    echo "{$title}<br />{$sum}<br />{$lcl_sum}";
}