dongyi1215 2015-05-05 07:59
浏览 280
已采纳

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

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!

  • 写回答

1条回答 默认 最新

  • douqiao5314 2015-05-05 08:58
    关注

    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;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 matlab用simulink求解一个二阶微分方程,要求截图
  • ¥30 matlab解优化问题代码
  • ¥15 写论文,需要数据支撑
  • ¥15 identifier of an instance of 类 was altered from xx to xx错误
  • ¥100 反编译微信小游戏求指导
  • ¥15 docker模式webrtc-streamer 无法播放公网rtsp
  • ¥15 学不会递归,理解不了汉诺塔参数变化
  • ¥15 基于图神经网络的COVID-19药物筛选研究
  • ¥30 软件自定义无线电该怎样使用
  • ¥15 R语言mediation包做中介分析,直接效应和间接效应都很小,为什么?