>백엔드 개발 >PHP 문제 >PHP는 2차원 배열에서 열의 합을 찾습니다.

PHP는 2차원 배열에서 열의 합을 찾습니다.

PHPz
PHPz원래의
2023-05-07 21:18:37878검색

PHP 개발 과정에서 배열의 데이터에 대한 합계 연산을 수행해야 하는 경우가 많습니다. 1차원 배열의 경우 array_sum 함수를 사용하여 직접 합계를 구할 수 있지만, 배열이 2차원 배열이 되는 경우 지정된 열의 합계를 구하려면 몇 가지 추가 연산이 필요합니다.

예를 들어 이제 판매 데이터를 저장하는 2차원 배열이 있습니다. 각 하위 배열은 제품 ID, 판매량, 단가 및 기타 정보를 포함한 제품의 판매 데이터를 나타냅니다. 판매량과 단가를 곱한 값인 모든 품목의 총 수익을 구해야 합니다.

그렇다면 이 작업을 어떻게 구현할까요?

먼저 array_column 함수를 사용하여 지정된 열의 배열을 가져올 수 있습니다. 이 함수는 PHP5.5+ 버전에 새로 추가되었습니다. 구문은 array_column ( array $input , Mixed $column_key [, Mixed $index_key = null ] )입니다. 그 중 $input 은 추출할 열의 배열입니다. column_key는 추출할 열입니다. $index_key는 선택 사항이며 반환된 배열의 키로 사용할 열의 키 이름 또는 숫자 인덱스입니다.

예를 들어, 위의 2차원 판매 데이터 배열에서 다음 코드를 사용하여 모든 제품의 판매 배열을 얻을 수 있습니다.

$sold_amount = array_column($sales_data, 'sold_amount');

다음으로 array_reduce 함수를 사용하여 $sold_amount 배열을 누적하여 얻을 수 있습니다. 판매량 합계. 구문은 다음과 같습니다. array_reduce ( array $array , callable $callback [, Mixed $initial = null ] ). 여기서 $array 는 누적할 배열이고 $callback 은 사용자 정의 콜백 함수이며 $initial 은 초기 값입니다.

예를 들어 다음 코드를 사용하여 모든 제품의 판매량 합계를 구할 수 있습니다.

$total_sold_amount = array_reduce($sold_amount, function($carry, $item){
    return $carry + $item;
});

다음으로 단가 배열에 대해 동일한 작업을 수행하여 모든 제품의 단가 합계를 구해야 합니다. . 마지막으로 두 합계를 곱하여 모든 항목의 총 수익을 얻을 수 있습니다.

전체 코드는 다음과 같습니다.

$sales_data = array(
    array('id' => 1, 'sold_amount' => 50, 'unit_price' => 2.5),
    array('id' => 2, 'sold_amount' => 20, 'unit_price' => 3.2),
    array('id' => 3, 'sold_amount' => 100, 'unit_price' => 1.8),
);

$sold_amount = array_column($sales_data, 'sold_amount');
$total_sold_amount = array_reduce($sold_amount, function($carry, $item){
    return $carry + $item;
});

$unit_price = array_column($sales_data, 'unit_price');
$total_unit_price = array_reduce($unit_price, function($carry, $item){
    return $carry + $item;
});

$total_revenue = $total_sold_amount * $total_unit_price;

echo '所有商品的总收入为:' . $total_revenue;

위 코드를 실행한 후 출력은 다음과 같습니다. 모든 제품의 총 수익은 630입니다.

요약하자면, 2차원 배열의 열에 합계 연산을 수행해야 할 경우 array_column 함수를 사용하여 지정된 열의 배열을 얻은 다음 array_reduce 함수를 사용하여 누적 연산을 수행할 수 있습니다. 열의 합계를 구하는 배열입니다. 이러한 방법을 통해 우리는 데이터를 보다 편리하게 처리하고 개발 효율성을 높일 수 있습니다.

위 내용은 PHP는 2차원 배열에서 열의 합을 찾습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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