Сортировка внутреннего индекса многомерного массива со столбцом в PHPPhp

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Сортировка внутреннего индекса многомерного массива со столбцом в PHP

Сообщение Anonymous »

У меня есть запись JSON, которую я преобразовал в массив PHP.

Код: Выделить всё

$db=array(
array("Name"=>"Beans","Price"=>"10"),
array("Name"=>"Salad","Price"=>"5"),
array("Name"=>"Bread","Price"=>"2"),
array("Name"=>"Lime","Price"=>"1")
);
Настоящая таблица данных такова.

Код: Выделить всё

Index   Name    Price
0       Beans   10
1       Salad   5
2       Bread   2
3       Lime    1
Когда я хочу получить имя первого элемента, я могу легко сделать это следующим образом:

Код: Выделить всё

$item=$db[0]['Name'];
Пока я не решил отсортировать массив по столбцу следующим образом:

Код: Выделить всё

array_multisort(array_column($db,'Price'),$db);
Тогда PHP думает о массиве следующим образом:

Код: Выделить всё

$db=array(
array("Name"=>"Lime","Price"=>"1"),
array("Name"=>"Bread","Price"=>"2"),
array("Name"=>"Salad","Price"=>"5"),
array("Name"=>"Beans","Price"=>"10"),
);
Это полностью портит внутреннюю индексацию, потому что теперь:

Код: Выделить всё

$item=$db[0]['Name'];
равно «Lime»
Есть ли способ получить предыдущий индекс перед сортировкой, чтобы я мог правильно ссылаться на записи.
Например, можно ли как-то использовать функции сортировки для перелистывания:

Код: Выделить всё

$db=array(
array("Name"=>"Beans","Price"=>"10"),
array("Name"=>"Salad","Price"=>"5"),
array("Name"=>"Bread","Price"=>"2"),
array("Name"=>"Lime","Price"=>"1")
);
что-то вроде:

Код: Выделить всё

$db=array(
array("Name"=>"Lime","Price"=>"1","index"=>3),
array("Name"=>"Lime","Price"=>"1","index"=>2),
array("Name"=>"Salad","Price"=>"5","index"=>1),
array("Name"=>"Beans","Price"=>"10","index"=>0),
);
но здесь индекс будет автоматически добавлен в массив, и моя программа сможет ссылаться на него при редактировании правильной информации. Идеи?

Подробнее здесь: https://stackoverflow.com/questions/793 ... umn-in-php
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

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