我有一个从数据库返回的用户对象,如下所示:
[ { "id":1,"name":"Bob","category":"admin","email":"test1@test.com","phone":"123456789","gender":"male",},{ "id":2,"name":"John","category":"user","email":"john@test.com",{ "id":3,"name":"Jane","email":"jane@test.com","gender":"female",]
现在,我想循环遍历所有用户对象,并删除其category属性为user的所有用户,以便生成的用户对象仅保留为admin类别.
我猜这个数组是JSON格式的吗?无论如何..我修复了你的无效JSON,所以你应该能够看到它是如何完成的.
$json = ' [{ "id": 1,"name": "Bob","category": "admin","email": "test1@test.com","phone": "123456789","gender": "male" },{ "id": 2,"name": "John","category": "user","email": "john@test.com",{ "id": 3,"name": "Jane","email": "jane@test.com","gender": "female" }] '; $array = json_decode($json,true); //Fixed and converted JSON into PHP Assoc Array foreach($array as $k=>$v) { foreach ($array[$k] as $key=>$value) { if ($key === "category" && $value === "user") { //If Value of 2D is equal to user and cat unset($array[$k]); //Delete from Array } } } var_dump($array); //Output Array
产量
array(2) { [0] => array(6) { ["id"] => int(1)["name"] => string(3) "Bob" ["category"] => string(5) "admin" ["email"] => string(14) "test1@test.com" ["phone"] => string(9) "123456789" ["gender"] => string(4) "male" }[2] => array(6) { ["id"] => int(3)["name"] => string(4) "Jane" ["category"] => string(5) "admin" ["email"] => string(13) "jane@test.com" ["phone"] => string(9) "123456789" ["gender"] => string(6) "female" } }
编辑
*正如@sevavietl在评论中指出的那样,如果数组的任何其他元素被称为user,那么这将被删除.我已经将代码更改为现在测试密钥(类别)以及值. *