>  기사  >  백엔드 개발  >  하나의 다차원 배열에는 있지만 다른 배열에는 없는 행을 찾는 방법은 무엇입니까?

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

Susan Sarandon
Susan Sarandon원래의
2024-11-09 09:39:02813검색

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()를 사용하여 비교할 수 있습니다. -차원 배열을 사용하여 차이를 구합니다.

$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',
  ),
)

위 내용은 하나의 다차원 배열에는 있지만 다른 배열에는 없는 행을 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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