二维数组的高级处理方法(一) [ 2.0 版本 ]
常见业务流程中的二维数组的简单处理方法
二维数组按照某个 key 去重
/*
* 二维数组去重
*/
public function assoc_unique($arr, $key)
{
$tmp_arr = array();
foreach ($arr as $k => $v) {
if (in_array($v[$key], $tmp_arr)) {//搜索$v[$key]是否在$tmp_arr数组中存在,若存在返回true
unset($arr[$k]);
} else {
$tmp_arr[] = $v[$key];
}
}
sort($arr); //sort函数对数组进行排序
return $arr;
}
按照数组中的某个值进行分组
/*
* 按某个值进行分组
*/
public static function getResult($model, $key = 'type', $content = 'content')
{
$query = $result = [];
if (!empty($model)) {
foreach ($model as $k => $v) {
$query[$v[$key]][] = $v;
}
}
$i = 0;
if (!empty($query)) {
foreach ($query as $k => $v) {
$result[$i][$key] = $k;
!empty($content) ? $result[$i][$content] = $v : '';
$i++;
}
}
return $result;
}
一行代码完成数组按照某个字段进行排序
/**
* 二维数组根据字段进行排序
* @params array $array 需要排序的数组
* @params string $field 排序的字段
* @params string $sort 排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
*/
function arraySequence($array, $field, $sort)
{
array_multisort(array_column($array,$field),$sort,$array);
}
删除二维数组中相同项的数据
/**
* 删除二维数组中相同项的数据,(一般用于数据库查询结果中相同记录的去重操作)
*
* @param array $_2d_array 二维数组,类似:
* $tmpArr = array(
* array('id' => 1, 'value' => '15046f5de5bb708e'),
* array('id' => 1, 'value' => '15046f5de5bb708e'),
* );
* @param string $unique_key 表示上述数组的 "id" 键,或者 "value" 键
*
* @return mixed
*/
function unique_2d_array_by_key($_2d_array, $unique_key)
{
$tmp_key[] = array();
foreach ($_2d_array as $key => &$item) {
if (is_array($item) && isset($item[$unique_key])) {
if (in_array($item[$unique_key], $tmp_key)) {
unset($_2d_array[$key]);
} else {
$tmp_key[] = $item[$unique_key];
}
}
}
return $_2d_array;
}
风叶 杭州
注册时间:2016-02-26
最后登录:2022-01-06
在线时长:4小时38分
最后登录:2022-01-06
在线时长:4小时38分
- 粉丝2
- 金钱645
- 威望10
- 积分785
共 0 条评论