백엔드 개발 PHP 튜토리얼 2D PHP 배열에서 열을 그룹화하고 합산하는 방법은 무엇입니까?

2D PHP 배열에서 열을 그룹화하고 합산하는 방법은 무엇입니까?

Oct 26, 2024 am 04:06 AM

How to Group and Sum Columns in a 2D PHP Array?

2D 배열의 열 그룹화 및 합산

이 작업은 각 요소가 행을 나타내는 PHP 데이터 배열을 처리하는 것입니다. 각 행은 url_id와 time_spent라는 두 개의 열로 구성됩니다. 목표는 url_id 열을 기준으로 행을 그룹화하고 각 그룹에 대해 time_spent 열의 값을 합산하는 것입니다.

해결책:

PHP의 array_count_values()를 사용할 수 있습니다. 이를 달성하기 위한 함수:

<code class="php">$ts_by_url = array_count_values(array_column($array, 'url_id'));</code>
로그인 후 복사

array_column() 함수는 입력 배열에서 url_id 열을 추출하여 url_id 값의 배열을 생성합니다. 그런 다음 array_count_values() 함수는 각 url_id 값의 발생 횟수를 계산하여 효과적으로 행을 그룹화합니다.

그러나 이 솔루션은 각 url_id에 대한 발생 횟수만 제공합니다. 각 그룹 내에서 time_spent 값을 합산하려면 접근 방식을 수정해야 합니다.

<code class="php">$ts_by_url = array();
foreach ($array as $data) {
    if (!array_key_exists($data['url_id'], $ts_by_url)) {
        $ts_by_url[$data['url_id']] = 0;
    }
    $ts_by_url[$data['url_id']] += $data['time_spent'];
}</code>
로그인 후 복사

이 업데이트된 접근 방식에서는 각 url_id에 대한 time_spent 값의 합계를 보관하는 $ts_by_url 배열을 유지 관리합니다. 입력 배열을 반복하여 해당 url_id가 $ts_by_url에 이미 있는지 각 행을 확인합니다. 그렇지 않은 경우 0 값으로 초기화합니다. 그럼에도 불구하고 $ts_by_url의 해당 url_id 항목에 time_spent 값을 추가합니다.

이 접근 방식을 사용하면 url_id별로 행을 그룹화하고 다음에 대한 time_spent 값을 합할 수 있습니다. 각 그룹. 결과 $ts_by_url 배열에는 url_id로 입력된 원하는 합계가 포함됩니다.

위 내용은 2D PHP 배열에서 열을 그룹화하고 합산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) 11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) Mar 03, 2025 am 10:49 AM

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)

Instagram API 소개 Instagram API 소개 Mar 02, 2025 am 09:32 AM

Instagram API 소개

Laravel의 플래시 세션 데이터로 작업합니다 Laravel의 플래시 세션 데이터로 작업합니다 Mar 12, 2025 pm 05:08 PM

Laravel의 플래시 세션 데이터로 작업합니다

Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Mar 12, 2025 pm 05:09 PM

Laravel 테스트에서 단순화 된 HTTP 응답 조롱

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 Mar 14, 2025 am 11:42 AM

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법

Laravel Back End : Part 2, React가있는 React 앱 구축 Laravel Back End : Part 2, React가있는 React 앱 구축 Mar 04, 2025 am 09:33 AM

Laravel Back End : Part 2, React가있는 React 앱 구축

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Mar 13, 2025 pm 12:08 PM

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트

라 라벨에서 알림 라 라벨에서 알림 Mar 04, 2025 am 09:22 AM

라 라벨에서 알림

See all articles