将数组中的值与另一个数组中的值进行匹配

将数组中的值与另一个数组中的值进行匹配

问题描述:

I have two different arrays with the following format:

$customersList = Array(
   Array('id' => null, 'title' => 'JOHN LEGEND'),
   Array('id' => null, 'title' => 'MARIAH CAREY'),
   Array('id' => null, 'title' => 'JAY Z'),
   Array('id' => null, 'title' => null),
);
$searchingValue = Array(
   Array('lastName' => 'TRAVOLTA', 'firstName' => 'JOHN'),
   Array('lastName' => 'CAREY', 'firstName' => 'MARIAH'),
   Array('lastName' => 'MODE', 'firstName' => 'DEPECHE'),
   Array('lastName' => 'BRUCE', 'firstName' => 'WILL'),
);

I want to match values from $customersList with values from $searchingValue based on the following algorithm: if ((firstName1 == $firstName 2 and $lastName1==$lastName2) or (firstName1 == lastName2 or lastName1 == firstName2) is true then do nothing else insert the new customer in $customersList.

My code is this:

$ignoreIfFound = true;
foreach ($searchingValue as $value) {
$uploadedAlready = false;
foreach ($customersList as $info) {
    if ($info['id'] === null and $info['title']) {
        list($paxLastName, $paxFirstName) = explode(' ', $info['title']);
        if (($paxLastName == $value['lastName'] and $paxFirstName == $value['firstName']) or ($paxLastName == $value['firstName'] and $paxFirstName == $value['lastName'])) {
         if (!$ignoreIfFound and !$uploadedAlready) {
            $customersList[] = Array('id' => null, 'title' => $value['lastName'].' '.$value['firstName']);
            $uploadedAlready = true;

            }
        }
        else {
            if (!$uploadedAlready) {
                $customersList[] = Array('id' => null, 'title' =>$value['lastName'].' '.$value['firstName']);
                $uploadedAlready = true;
            }
        }
    }
    else {
        if (!$uploadedAlready) {
            $customersList[] = Array('id' => null, 'title' => $value['lastName'].' '.$value['firstName']);
            $uploadedAlready = true;

        }
    }
}}

But it is not working properly. For given example the new customersList should be:

$customersList = Array(
   Array('id' => null, 'title' => 'JOHN LEGEND'),
   Array('id' => null, 'title' => 'MARIAH CAREY'),
   Array('id' => null, 'title' => 'JAY Z'),
   Array('id' => null, 'title' => null),
   Array('id' => null, 'title' => 'TRAVOLTA JOHN'),
   Array('id' => null, 'title' => 'MODE DEPECHE'),
   Array('id' => null, 'title' => 'BRUCE WILL'),
);

Thank you in advance!

Build an Map of all already founded Keys (Firstname, Lastname and First+Lastname) and check against:

<?php
$alreadyInList = array ();

foreach ( $customersList as $customer) {
    $alreadyInList[$customer["title"]] = true;
    $firstLastname = explode(" ", $customer["title"]);
    $alreadyInList[$firstLastname[0]] = true;
    $alreadyInList[$firstLastname[1]] = true;
}

foreach($searchingValue as $search) {
    if (array_key_exists($alreadyInList, $search["lastname"]))
        continue;
    if (array_key_exists($alreadyInList, $search["firstname"]))
        continue;
    if (array_key_exists($alreadyInList, $search["firstname"] . " " . $search["lastname"]))
        continue;

    $customersList[] = new array() // ... insert

    $alreadyInList[$search["firstname"] . " " . $search["lastname"]] = true;
    $alreadyInList[$search["lastname"]] = true;
    $alreadyInList[$search["firstname"]] = true;
}