首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在两个数组中获得最佳逻辑

在两个数组中获得最佳逻辑
EN

Stack Overflow用户
提问于 2017-03-20 19:09:34
回答 4查看 107关注 0票数 0

我有一个数据数组。

代码语言:javascript
复制
$data_arr = array(
       0 =>array(
           "id" => "nis-0",
           "name" =>"nam1-0",
           "age"=>11
       ),
       1 =>array(
           "id" => "nis-1",
           "name" =>"nama-1",
           "age"=>15
       ),
       2 =>array(
           "id" => "nis-2",
           "name" =>"nama-2",
           "age"=>10
       ),
       3 =>array(
           "id" => "nis-3",
           "name" =>"nama-3",
           "usia"=>13
       ),
       4 =>array(
           "id" => "nis-4",
           "name" =>"nama-4",
           "age"=>14
       )
   );

$filter_data = ['nis-1','nis-2'];

我需要得到$filter数据中的平均年龄。在这种情况下,应该是get result average:(15 + 10 )/2 = 12.5

哦,是的,然后我在data $data_arr中有100万个数据,在$filter_data中有100000个数据。并且脚本必须步行不到2分钟。我需要执行最好的逻辑

EN

回答 4

Stack Overflow用户

发布于 2017-03-20 19:48:24

简单地如下所示:

代码语言:javascript
复制
$keys = array_column($data_arr, 'age', 'id');
array_walk($keys, function($v, $k) use(&$list, $filter_data) {
    if (in_array($k, $filter_data))
    $list[] = $v;
});

print_r(array_sum($list) / count($list));
// Output : 12.5

实时视图:https://3v4l.org/ldhqA

更新:

感谢Casimir et Hippolyte

您可以简单地按key进行过滤,如下所示:

代码语言:javascript
复制
$keys = array_column($data_arr, 'age', 'id');
$list = array_intersect_key($keys, array_flip($filter_data));

print_r(array_sum($list) / count($list));
票数 2
EN

Stack Overflow用户

发布于 2017-03-20 19:19:02

下面是一个简单的代码片段,它仅根据数据数组和filter_data数组中的元素计算平均年龄

代码语言:javascript
复制
$vals=array();
foreach($data_arr as $arr){
  if(in_array(arr['id'],$filter_data){
     //store the ages with ids matching filter array
     array_push($vals,arr['age']);
  }
}
//total elements
$count=sizeof($vals);
//sum of elements
$sum=array_sum($vals);
echo "Avg ages = ".$sum/$count;
票数 1
EN

Stack Overflow用户

发布于 2017-03-20 19:21:00

代码语言:javascript
复制
// reduce result set to valid items as in $filter_data and having 'age' index
$validItems = array_filter(
  $data_arr,
  function ($item) use ($filter_data) {
    return isset($item['age']) && in_array($item['id'], $filter_data);
  }
);
// extract value from 'age' index
$validAges = array_map(
  function ($item) {
    return $item['age'];
  },
  $validItems
);
// execute calculation
$averageAge = array_sum($validAges) / count($validAges);
var_dump($averageAge); // outputs 12.5 for the $filter_data of the question

然而,正如已经在评论中提到的,最有效的方法是限制已经检索的$data_arr的结果集,这意味着只查询相关数据并可能在那里执行计算-但是最初的问题没有提到数据是从数据库中提取的还是从例如XML中解析的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42902069

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档