Распечатайте отдельную таблицу HTML для каждой группы в многомерном массиве.Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Распечатайте отдельную таблицу HTML для каждой группы в многомерном массиве.

Сообщение Anonymous »

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

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

Это массив, который я использую

$result = Array(
0 => Array (
'supplier' => 'Supplier 1',
'descr' => 'Product 1',
'id' => '123',
'quantity' => '5',
),
1 => Array (
'supplier' => 'Supplier 1',
'descr' => 'Product 2',
'id' => '345',
'quantity' => '1',
),
2 => Array (
'supplier' => 'Supplier 2',
'descr' => 'Product 3',
'id' => '567',
'quantity' => '10',
),
3 => Array (
'supplier' => 'Supplier 1',
'descr' => 'Product 4',
'id' => '789',
'quantity' => '1',
),
4 => Array (
'supplier' => 'Supplier 3',
'descr' => 'Product 5',
'id' => '111',
'quantity' => '6',
),
5 => Array (
'supplier' => 'Supplier 4',
'descr' => 'Product 6',
'id' => '222',
'quantity' => '30',
)
);


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

$arr = array();
foreach($result as $key => $value) {
$arr[$value['supplier']][$key] = $value;
}

ksort($arr, SORT_NUMERIC);


После этого я начал создавать такие таблицы

echo '';

foreach($arr as $id) {
foreach($id as $key => $value) {

echo '';
echo ''.$value['supplier'].'';
echo ''.$value['descr'].'';
echo ''.$value['id'].'';
echo ''.$value['quantity'].'';
echo '';

// different supplier so start new table
if(current($value['supplier']) != next($value['supplier'])){
echo '';
}
}
}

echo '';


Но при этом создается только одна таблица. И когда я меняю оператор на ==, создается 5 отдельных таблиц.

/edit

Идеальный результат был бы



Supplier 2
Product 3
567
6





Supplier 1
Product 1
123
5


Supplier 1
Product 2
345
1


Supplier 1
Product 4
789
1





Supplier 3
Product 5
111
30





Supplier 4/td>
Prodcut 6
222
10




Подробнее здесь: https://stackoverflow.com/questions/360 ... onal-array
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»