当转换为具有有效整数的字符串键的对象时,会出现此问题。array
如果您有此对象:
object(stdClass)#1 (2) {
["207"]=>
string(3) "sdf"
["210"]=>
string(3) "sdf"
}
你用它铸造
$array = (array)$object
你得到这个数组
array(2) {
["207"]=>
string(3) "sdf"
["210"]=>
string(3) "sdf"
}
它具有只能通过循环访问的密钥,因为直接访问 like 将始终转换为 不存在。$array["207"]
$array[207]
由于您正在将像上面这样的对象应用于字符串json_decode()
$json = '{"207":"sdf", "210":"sdf"}'
最好的解决方案是首先避免使用数字键。这些可能更好地建模为对象数组的数值属性:
$json = '[{"numAttr":207, "strAttr":"sdf"}, {"numAttr":210, "strAttr":"sdf"}]'
与现在的数据结构相比,此数据结构有几个优点:
- 它更好地反映了原始数据,作为具有数字属性的对象的集合
- 它很容易与其他属性一起扩展
- 它在不同的系统中更具可移植性(如您所见,您当前的数据结构在PHP中引起了问题,但是如果您碰巧使用另一种语言,则可能很容易遇到类似的问题)。
如果需要属性→对象映射,则可以快速获取它,例如,如下所示:
function getNumAttr($obj) { return $obj->numAttr; } // for backward compatibility
$arr = json_decode($json); // where $json = '[{"numAttr":...
$map = array_combine(array_map('getNumAttr', $arr), $arr);
另一种解决方案是按照 ascii-lime 的建议执行操作:强制 json_decode()
输出关联数组而不是对象,方法是将其第二个参数设置为 :true
$map = json_decode($json, true);
对于您的输入数据,这直接产生
array(2) {
[207]=>
string(3) "sdf"
[210]=>
string(3) "sdf"
}
请注意,数组的键现在是整数而不是字符串。
不过,我认为更改JSON数据结构是一个更干净的解决方案,尽管我知道这样做可能是不可能的。