Php 重新排列数组索引
从一个数组中删除一个元素后,我出现了一个错误 房产有房间Php 重新排列数组索引,php,arrays,json,laravel,unset,Php,Arrays,Json,Laravel,Unset,从一个数组中删除一个元素后,我出现了一个错误 房产有房间 foreach ($property->rooms as $key => $room) { if ($room->type == 1 and $type ==1 and $room->price < $price->min or $room->price > $price->max) { print_r($property->rooms);
foreach ($property->rooms as $key => $room) {
if ($room->type == 1 and $type ==1 and $room->price < $price->min or $room->price > $price->max) {
print_r($property->rooms);
unset($property->rooms[$key]);
//$array = array_values($property->rooms); doesn't work
print_r($property->rooms);
}
}
)
取消设置后的
Illuminate\Database\Eloquent\Collection Object
(
[items:protected] => Array
(
[0] => Room Object
(
[table:protected] => rooms
[fillable:protected] => Array
(
[0] => properties_id
[1] => price
[2] => is_available
[3] => type
[4] => description
)
[connection:protected] =>
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
(
[id] => 1
[properties_id] => 4
[price] => 450000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-20 22:27:44
[type] => 1
[description] =>
)
[original:protected] => Array
(
[id] => 1
[properties_id] => 4
[price] => 450000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-20 22:27:44
[type] => 1
[description] =>
)
[relations:protected] => Array
(
)
[hidden:protected] => Array
(
)
[visible:protected] => Array
(
)
[appends:protected] => Array
(
)
[guarded:protected] => Array
(
[0] => *
)
[dates:protected] => Array
(
)
[touches:protected] => Array
(
)
[observables:protected] => Array
(
)
[with:protected] => Array
(
)
[morphClass:protected] =>
[exists] => 1
)
[1] => Room Object
(
[table:protected] => rooms
[fillable:protected] => Array
(
[0] => properties_id
[1] => price
[2] => is_available
[3] => type
[4] => description
)
[connection:protected] =>
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
(
[id] => 2
[properties_id] => 4
[price] => 350000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-21 18:13:15
[type] => 1
[description] =>
)
[original:protected] => Array
(
[id] => 2
[properties_id] => 4
[price] => 350000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-21 18:13:15
[type] => 1
[description] =>
)
[relations:protected] => Array
(
)
[hidden:protected] => Array
(
)
[visible:protected] => Array
(
)
[appends:protected] => Array
(
)
[guarded:protected] => Array
(
[0] => *
)
[dates:protected] => Array
(
)
[touches:protected] => Array
(
)
[observables:protected] => Array
(
)
[with:protected] => Array
(
)
[morphClass:protected] =>
[exists] => 1
)
[2] => Room Object
(
[table:protected] => rooms
[fillable:protected] => Array
(
[0] => properties_id
[1] => price
[2] => is_available
[3] => type
[4] => description
)
[connection:protected] =>
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
(
[id] => 3
[properties_id] => 4
[price] => 250000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 0000-00-00 00:00:00
[type] => 1
[description] =>
)
[original:protected] => Array
(
[id] => 3
[properties_id] => 4
[price] => 250000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 0000-00-00 00:00:00
[type] => 1
[description] =>
)
[relations:protected] => Array
(
)
[hidden:protected] => Array
(
)
[visible:protected] => Array
(
)
[appends:protected] => Array
(
)
[guarded:protected] => Array
(
[0] => *
)
[dates:protected] => Array
(
)
[touches:protected] => Array
(
)
[observables:protected] => Array
(
)
[with:protected] => Array
(
)
[morphClass:protected] =>
[exists] => 1
)
)
Illuminate\Database\Eloquent\Collection Object
(
[items:protected] => Array
(
[1] => Room Object
(
[table:protected] => rooms
[fillable:protected] => Array
(
[0] => properties_id
[1] => price
[2] => is_available
[3] => type
[4] => description
)
[connection:protected] =>
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
(
[id] => 2
[properties_id] => 4
[price] => 350000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-21 18:13:15
[type] => 1
[description] =>
)
[original:protected] => Array
(
[id] => 2
[properties_id] => 4
[price] => 350000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 2014-10-21 18:13:15
[type] => 1
[description] =>
)
[relations:protected] => Array
(
)
[hidden:protected] => Array
(
)
[visible:protected] => Array
(
)
[appends:protected] => Array
(
)
[guarded:protected] => Array
(
[0] => *
)
[dates:protected] => Array
(
)
[touches:protected] => Array
(
)
[observables:protected] => Array
(
)
[with:protected] => Array
(
)
[morphClass:protected] =>
[exists] => 1
)
[2] => Room Object
(
[table:protected] => rooms
[fillable:protected] => Array
(
[0] => properties_id
[1] => price
[2] => is_available
[3] => type
[4] => description
)
[connection:protected] =>
[primaryKey:protected] => id
[perPage:protected] => 15
[incrementing] => 1
[timestamps] => 1
[attributes:protected] => Array
(
[id] => 3
[properties_id] => 4
[price] => 250000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 0000-00-00 00:00:00
[type] => 1
[description] =>
)
[original:protected] => Array
(
[id] => 3
[properties_id] => 4
[price] => 250000
[is_available] => 1
[created_at] => 0000-00-00 00:00:00
[updated_at] => 0000-00-00 00:00:00
[type] => 1
[description] =>
)
[relations:protected] => Array
(
)
[hidden:protected] => Array
(
)
[visible:protected] => Array
(
)
[appends:protected] => Array
(
)
[guarded:protected] => Array
(
[0] => *
)
[dates:protected] => Array
(
)
[touches:protected] => Array
(
)
[observables:protected] => Array
(
)
[with:protected] => Array
(
)
[morphClass:protected] =>
[exists] => 1
)
)
)
转换为json后,rooms字段应为数组而不是对象:
{"other_parameters": "something","rooms":{"1":{"id":2,"properties_id":4,"price":350000,"is_available":1,"created_at":"-0001-11-30 00:00:00","updated_at":"2014-10-21 18:13:15","type":1,"description":null},"2":{"id":3,"properties_id":4,"price":250000,"is_available":1,"created_at":"-0001-11-30 00:00:00","updated_at":"-0001-11-30 00:00:00","type":1,"description":""}}}
选项1
$array = array();
foreach ($property->rooms as $key => $room) {
if ($room->type == 1) {
unset($property->rooms->{$key}); <<-- pay attention to this
} else {
$array[] = get_object_vars($room); // sort the passed row into new array
}
}
print_r($array);
我在laravel文档中找到了一个解决方案 修改数组后,必须从laravel集合调用名为values()的方法来排列数组索引,例如:
unset($property->rooms[$key]);
$property->rooms->values();
请将$property->rooms的原始php对象发布到文档中,您在哪里找到了它@米格尔
unset($property->rooms[$key]);
$property->rooms->values();