"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 하나의 다차원 배열에는 있지만 다른 배열에는 없는 행을 찾는 방법은 무엇입니까?

하나의 다차원 배열에는 있지만 다른 배열에는 없는 행을 찾는 방법은 무엇입니까?

2024년 11월 17일에 게시됨
검색:729

How to Find Rows Present in One Multidimensional Array but Not in Another?

다차원 배열의 연관 행 비교

$pageids와 $parentpage라는 두 개의 다차원 배열이 있습니다. 여기서 각 행은 열이 있는 레코드를 나타냅니다. 'id', 'linklabel', 'url'입니다. $pageids에는 있지만 $parentpage에는 없는 행을 찾고 누락된 행이 있는 배열($pageWithNoChildren)을 효과적으로 생성하려고 합니다.

그러나 이러한 배열에서 직접 array_diff_assoc()을 사용하면 예상대로 작동하지 않습니다. 중첩된 행의 내용이 아닌 기본 배열 키를 비교하기 때문입니다. 중첩된 행을 비교하려면 먼저 array_map() 및 serialize() 함수를 사용하여 이를 1차원 배열로 변환할 수 있습니다.

$serializedPageids = array_map('serialize', $pageids);
$serializedParentpage = array_map('serialize', $parentpage);

변환 후 array_diff()를 사용하여 이러한 1차원 배열을 비교하고 차이를 얻을 수 있습니다.

$serializedDifference = array_diff($serializedPageids, $serializedParentpage);

마지막으로 array_map() 및 unserialize() 함수를 사용하여 직렬화된 차이를 다시 다차원 배열로 변환합니다.

$pageWithNoChildren = array_map('unserialize', $serializedDifference);

이 프로세스를 통해 내용을 비교할 수 있습니다. 중첩된 행을 제거하고 $pageids에는 있지만 $parentpage에는 없는 행을 추출하여 예상되는 결과를 얻습니다. 출력:

array (
  0 =>
  array (
    'id' => 1,
    'linklabel' => 'Home',
    'url' => 'home',
  ),
  3 =>
  array (
    'id' => 6,
    'linklabel' => 'Logo Design',
    'url' => 'logodesign',
  ),
  4 =>
  array (
    'id' => 15,
    'linklabel' => 'Content Writing',
    'url' => 'contentwriting',
  ),
)
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3