Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 1
Регистрация: 19.07.2016
Сообщений: 18
1

Преобразовать массив для вывода в html таблицу, объединить ячейки с одинаковыми значениями

13.01.2021, 06:24. Показов 892. Ответов 1

Прошу помощи с переборкой массива для дальнейшего вывода в html таблицу. Из БД выгружается вот такой массив, который выводится в таблицу.

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
Array ( 
    [0] => Array (
          [report_id] => 6573
          [date] => 2020-12-28
          [comment] => Отчет принят 
    ) 
    [1] => Array ( 
          [report_id] => 6580 
          [date] => 2020-12-29 
          [comment] => Отчет на проверке 
    ) 
    [2] => Array ( 
          [report_id] => 6825 
          [date] => 2020-12-30 
          [comment] => Отчет на проверке 
    ) 
    [3] => Array ( 
          [report_id] => 6658 
          [date] => 2020-12-31 
          [comment] => Отчет на проверке
    ) 
    [4] => Array ( 
          [report_id] => 6828 
          [date] => 2021-01-02
          [comment] => Отчет на проверке 
    ) 
    [5] => Array ( 
          [report_id] => 7509
          [date] => 2021-01-03 
          [comment] => Отчет не принят 
    )
    [6] => Array ( 
          [report_id] => 7519
          [date] => 2021-01-04 
          [comment] => На доработку 
    )
    [7] => Array ( 
          [report_id] => 7559
          [date] => 2021-01-05 
          [comment] => На доработку
    )
    [8] => Array ( 
          [report_id] => 7561
          [date] => 2021-01-07 
          [comment] => Отчет на проверке
    )
)
Нужно объединить одинаковые значения в последнем столбике [comment], чтобы привести таблицу вот к такому виду. Объединять нужно максимум 4 одинаковых значения. 5-ое одинаковое подряд значение не объединяется с предыдущими 4.

Преобразовать массив для вывода в html таблицу, объединить ячейки с одинаковыми значениями


Понимаю, что мне нужно посчитать rowspan, но не могу сообразить как
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.01.2021, 06:24
Ответы с готовыми решениями:

Копирование ячейки из 1 файла в другой с одинаковыми значениями
Доброе время суток ! Прошу помоч с написанием макроса или возможного решения следующей проблемы:...

Макрос объединяющий ячейки с одинаковыми значениями, но с разными условиями
Здравствуйте! Подскажите пожалуйста у кого-либо есть макрос, который может объединять ячейки с...

Объединить ячейки с повторяющимися значениями
Добрый день.. Делаю выгрузку в Excel, на рисунке показано что получается после выгрузки, ( эти...

Массив с одинаковыми значениями
нужна программа которая будет определять есть ли одинаковые цифры в массиве введенном с клавиатуры

1
502 bad gateway
Эксперт PHP
4530 / 3685 / 1545
Регистрация: 24.04.2014
Сообщений: 10,851
13.01.2021, 12:25 2
Лучший ответ Сообщение было отмечено Rickie как решение

Решение

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$groups = [];
foreach ($array as $a) {
    $groups[$a['comment']] = $a;
}
echo '<table>';
foreach ($groups as $group) {
    echo '<tr>';
    foreach ($group as $i => $row) {
        printf('<td>%d</td><td>%s</td>', $row['report_id'], htmlentities($row['date'], ENT_QUOTES));
        if ($i === 0) {
            printf('<td rowspan="%d">%s</td>', count($group), htmlentities($row['comment'], ENT_QUOTES));
        }
    }
    echo '</tr>';
}
echo '</table>';
Добавлено через 5 минут
Не заметил условие на максимум 4 объединённых строки, можно использовать array_chunk для решения, но мне уже лень изменять
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.01.2021, 12:25

Заказываю контрольные, курсовые, дипломные работы и диссертации здесь.

Массив с одинаковыми значениями
Почему, если скормить &quot;a&quot;,&quot;b&quot;,&quot;c&quot; получается &quot;ccc&quot; а не &quot;abc&quot; ? #include &lt;iostream&gt; ...

двумерный массив с одинаковыми значениями
как можно проверить столбец на наличие одинаковых цифр или текста?(в двумерном массиве)

Массив заполняется одинаковыми значениями
Друзья очень глупый вопрос. Прям стыдно в папке 4 файла /opt/.DS_Store /opt/1.dmg...

Массив: Определить, есть ли в заданном массиве элементы с одинаковыми значениями...
Введите массив из 20 элементов и определите, есть ли в нем элементы с одинаковыми значениями

Преобразовать массив цифр в строку для вывода на cout<<
Реализую класс длинных чисел (только+). Числа представляю в виде массиве, где каждый элемент это...

Введите массив из 20 элементов и определите, есть ли в нем элементы с одинаковыми значениями
помогите решить залачу с помощю подпрограммой !!!!! задача(270): Введите массив из 20...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.