>백엔드 개발 >PHP 튜토리얼 >PHP_php 기술에서 array_map과 array_column 간의 관계 분석

PHP_php 기술에서 array_map과 array_column 간의 관계 분석

WBOY
WBOY원래의
2016-05-16 20:38:031401검색

이 글은 PHP에서 array_map과 array_column의 관계를 예시 형태로 분석한 것입니다.

array_map() 및 array_column()은 다음과 같이 사용됩니다.

array_map(); 주어진 배열의 셀에 콜백 함수를 적용합니다
array_column(); 빠른 구현: 2차원 배열을 1차원 배열로 변환

array_column() 함수 형식은 다음과 같습니다.

배열 array_column ( 배열 $input , 혼합 $column_key [, 혼합 $index_key ] );

입력 배열에서 값이 column_key인 열을 반환합니다. 선택적 매개변수 index_key가 지정된 경우 반환된 배열의 해당 키는 입력 배열 값 index_key에 해당하는 값입니다.

샘플 코드 1:

$records = array(
  array(
    'id' => 2135,
    'first_name' => 'John',
    'last_name' => 'Doe',
  ),
  array(
    'id' => 3245,
    'first_name' => 'Sally',
    'last_name' => 'Smith',
  ),
  array(
    'id' => 5342,
    'first_name' => 'Jane',
    'last_name' => 'Jones',
  ),
  array(
    'id' => 5623,
    'first_name' => 'Peter',
    'last_name' => 'Doe',
  )
);
 
$first_names = array_column($records, 'first_name');
print_r($first_names);

출력:

Array
(
  [0] => John
  [1] => Sally
  [2] => Jane
  [3] => Peter
)

샘플 코드 2:

$last_names = array_column($records, 'last_name', 'id');
print_r($last_names);

출력:

Array
(
  [2135] => Doe
  [3245] => Smith
  [5342] => Jones
  [5623] => Doe
)

array_column() 함수가 없을 경우

array_map()을 사용하여 예제 1 구현:

$a = array_map(function($element){  //$records作为参数传入回调函数
  return $element['last_name'];  //返回数组元素值的last_name对应值
}, $records);            //array_map返回数组,相当于把每个$element['last_name']存入新数组,所以是新建的索引

foreach를 사용하여 예제 1 구현:

foreach($records as $v)
{
  $b[] = $v['last_name'];
}
使用foreach实现例二:
$c = array();
foreach($records as $k=>$v)
{
 $c += array($v['id']=>$v['last_name']); //使用+运算符, 以追加的形式(不改变原数组索引), 合并组装的数组
}                 //若使用array_merge,数字键名将被重新编号

꺼낸 여러 데이터 중 일반적인 2차원 배열의 경우 해당 값에 해당하는 데이터의 단일 값을 사용해야 하는 경우 array_column()을 사용하여 완성할 수 있습니다. 그러나 더 복잡한 배열의 경우에는 이를 완료할 수 있습니다. 구조, foreach는 더 유연하지만 시스템 기능을 먼저 사용하는 것이 항상 선호됩니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.