Php проверить и заменить, если значение существует в нескольких массивах? - PullRequest
2 голосов
/ 18 марта 2019

Проблема:

Я не знаю / не понимаю, как проверить, существуют ли дата и место в одной и той же «строке» и существуют ли они более одного раза.Во-вторых, как мне затем объединить массив в моем случае MergeArray с ArraySchedule

Код:

$ArraySchedule = array();
while ($data = $stmt -> fetch(PDO::FETCH_ASSOC)) {

    $schedules = array(
        "id" => $data['id'],
        "name" => $data['name'],
        "date" => $data['date'],
        "time" => $data['time'],
        "place_id" => $data['place_id'],
        "place" => $data['place'],


    );
    array_push($ArraySchedule, $schedules);

}
$dupe_array = array();
foreach ($ArraySchedule as $key => $value) {
   if(++$dupe_array[$value["date"]] > 1 && ++$dupe_array[$value["place_id"]] > 1 ){
    // this statement is wrong, i want something like: 
    // if date and place_id exists on the same "row" and they exists more then once 
 }
}

Что я хочуdo:

Проверьте, содержит ли ArraySchedule расписания с одинаковыми датой и местом, если существует более одного расписания с одинаковой датой и place_id.затем я хочу обновить ArraySchedule с этой структурой

$MergeArray = array(
        "id" => ArraySchedule['id'],
        "name" => array(
            "name" => scheduleSameDateAndPlace['name'],
            "name" => scheduleSameDateAndPlace['name'],
            "name" => scheduleSameDateAndPlace['name'],
        ),
        "date" => $ArraySchedule['date'],
        "time" => $ArraySchedule['time'],
        "place_id" => $ArraySchedule['place_id'],
        "place_name" => $ArraySchedule['place_name'],
    ),

MergeArray с ArraySchedule?в любом случае ...

Вывод я думаю, что хочу?

Print_r($ArraySchedule) 
        array(
            [0] => 
                array(
                    [id] => 1 
                    [names] => Simon 
                    [date] => 2019-01-02 
                    [time] 18.00 
                    [place_id] => Tystberga Park 
                    [place] => Tystberga
                )
            [1] => 
                array(
                    [id] => 2 
                    //[names] insted of [name]?
                    [names] => 
                        array(
                            [name] => Vincent 
                            [name] => Angel 
                            [name] => Kim
                        )
                    [date] => 2019-02-17
                    [time] => 13.00
                    [place_id] => Borås Park
                    [place] => Borås
                )
            [2] => 
                array(
                    [id] => 3
                    // [names] is always an array?
                    [names] => Caitlyn 
                    [date] => 2019-03-15 
                    [time] 13.00 
                    [place_id] => Plaza Park 
                    [place] => EvPark
                )
        ) 

Ответы [ 2 ]

1 голос
/ 18 марта 2019

Вы можете использовать array-Reduce . Учтите следующее:

function mergeByDateAndPlace($carry, $item) {
    $key = $item["place_id"] . $item["date"]; // creating key matching exact place and date
    if (!isset($carry[$key])) {
        $carry[$key]["name"] = $item["name"]; 
    } else {
        $carry[$key] = $item; 
        $item["name"] = [$item["name"]]; // make default array with 1 element so later can be append other names
    }
    return $carry;
}

Теперь используйте его с:

$MergeArray = array_reduce($ArraySchedule, "mergeByDateAndPlace", []);

Если позже вы захотите узнать, есть ли дубликаты, вы можете просто зацикливаться на $MergeArray. Вы также можете использовать array_values, если хотите сбросить ключи concat.

Обратите внимание на @Nick 2 важных комментария о сохранении первого цикла и значения "времени", которое необходимо решить. Также обратите внимание, что ваш вывод содержит многоэлемент с одним и тем же ключом («name») - вам нужно добавить их с помощью ключа int - Массив не может иметь дублирующихся ключей.

Надеюсь, это поможет!

0 голосов
/ 20 марта 2019

Вот мои данные из моей базы данных:

var_export ($ ArraySchedule)

array ( 
 0 => array ( 'id' => '225', 'place_id' => 'Alviks Kulturhus', 'name' => 'BarraBazz', 'date' => '2019-03-19', 'placeadress' => 'Gustavslundsvägen 1', ), 
 1 => array ( 'id' => '229', 'place_id' => 'Axelhuset Göteborg', 'name' => 'Anders Björk', 'date' => '2019-04-08', 'placeadress' => 'Axel Dahlströms torg 3', ), 
 2 => array ( 'id' => '230', 'place_id' => 'Axelhuset Göteborg', 'name' => 'Black Jack', 'date' => '2019-04-08', 'placeadress' => 'Axel Dahlströms torg 3', ), 
 3 => array ( 'id' => '227', 'place_id' => 'Arosdansen Syrianska Kulturcentret', 'name' => 'BarraBazz', 'date' => '2019-05-08', 'placeadress' => 'Narvavägen 90', ), 
 4 => array ( 'id' => '228', 'place_id' => 'Aspåsnäset', 'name' => 'Blender', 'date' => '2019-05-25', 'placeadress' => 'Aspåsnäset 167', ), 
 5 => array ( 'id' => '226', 'place_id' => 'Arenan Västervik Resort', 'name' => 'Blender', 'date' => '2019-06-29', 'placeadress' => 'Lysingsvägen', ), 
 6 => array ( 'id' => '222', 'place_id' => 'Alingsåsparken', 'name' => 'Bendéns', 'date' => '2019-07-16', 'placeadress' => 'Folkparksgatan 3A', ), 
 7 => array ( 'id' => '223', 'place_id' => 'Alingsåsparken', 'name' => 'Charlies', 'date' => '2019-07-16', 'placeadress' => 'Folkparksgatan 3A', ), 
 8 => array ( 'id' => '224', 'place_id' => 'Allhuset Södertälje', 'name' => 'Cedrix', 'date' => '2019-07-16', 'placeadress' => 'Barrtorpsvägen 1A', ), )

Я хочу обновить имя с помощьюмассив имен каждый раз, когда place_id и дата совпадают.

Это вывод, который я хочу:

Array ( 
[0] => 
    Array ( [id] => 225 [place_id] => Alviks Kulturhus [name] => BarraBazz [date] => 2019-03-19 [placeadress] => Gustavslundsvägen 1 ) 
[1] => 
    Array ( [id] => 229 [place_id] => Axelhuset Göteborg [name] => Array([0] => Anders Björk [1] => Black Jack )  [date] => 2019-04-08 [placeadress] => Axel Dahlströms torg 3 ) 
[3] => 
    Array ( [id] => 227 [place_id] => Arosdansen Syrianska Kulturcentret [name] => BarraBazz [date] => 2019-05-08 [placeadress] => Narvavägen 90 ) 
[4] => 
    Array ( [id] => 228 [place_id] => Aspåsnäset [name] => Blender [date] => 2019-05-25 [placeadress] => Aspåsnäset 167 ) 
[5] => 
    Array ( [id] => 226 [place_id] => Arenan Västervik Resort [name] => Blender [date] => 2019-06-29 [placeadress] => Lysingsvägen ) 
[6] => 
    Array ( [id] => 222 [place_id] => [Alingsåsparken] [name] => Array([0] => Bendéns [1] => Charlies) [date] => 2019-07-16 [placeadress] => Folkparksgatan 3A ) 
[8] =>
    Array ( [id] => 224 [place_id] => Allhuset Södertälje [name] => Cedrix [date] => 2019-07-16 [placeadress] => Barrtorpsvägen 1A ) )

Вот мой обновленныйкод

$sql = "SELECT `schedule`.`id`,`schedule`.`place_id`,`schedule`.`name`,`schedule`.`date`,`places`.`placeadress` FROM `schedule` INNER JOIN `places` ON `schedule`.`place_id`=`places`.`place_id` ORDER BY `date`";
$stmt = $db -> prepare($sql);
$stmt -> execute();
$ArraySchedule = $stmt->fetchAll(PDO::FETCH_ASSOC);
var_export($ArraySchedule);
$DatePlace = array();
    foreach ($ArraySchedule as $key => $Schedule){

        $Arrayquery = "SELECT `schedule`.`id`,`schedule`.`place_id`,`schedule`.`name`,`schedule`.`date`,`places`.`placeadress` FROM `schedule` INNER JOIN `places` ON `schedule`.`place_id`=`places`.`place_id` WHERE `schedule`.`date`= :date_ AND `schedule`.`place_id` = :place_id ORDER BY `date`";
        $ArrayStmt = $db->prepare($Arrayquery);
        $ArrayStmt -> execute(array(":date_" => $Schedule['date'],":place_id" => $Schedule['place_id']));
        //Getting every $Schedule that has the same date and place_id
        if($ArrayStmt->rowCount() > 1){

            //Here i want two update the name inside 
            //$ArrayArraySchedule with an array of names 
            //that has the same place and date?


        }
    }
print_r($ArraySchedule);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...