我有一个XML文件,其中某些标签偶尔可能为空。当我使用PHP读取此文件并使用json_encode对其进行编码时,JSON会将所有空标记转换为空对象,而我更喜欢它们 - 空字符串。停止/避免这种转换的最佳方法是什么?
编辑: 我不想从XML中删除这些标记,因为我没有特定标记的XML条目和此标记为空的XML条目之间存在差异。
编辑2: 样本输入:
<Family>
<name>aaa</name>
<adults>3</adults>
<kids />
</Family>
kids 标记为空
我希望将编码结果作为
Family[1].name = 'aaa';
Family[1].adults = 3;
Family[1].kids = '';
我得到的是:
Family[1].name = 'aaa';
Family[1].adults = 3;
Family[1].kids = Object(); //empty
EDIT3:
我的实施非常简单:
PHP中的
$xml = simplexml_load_file($filepath);
echo json_encode($xml, JSON_NUMERIC_CHECK);
JavaScript中的
objJson = $.parseJSON(xmlhttp.responseText);
....
d["name"] = objJson.Family[i].name;
d["adults"] = objJson.Family[i].adults;
d["kids"] = objJson.Family[i].kids;
答案 0 :(得分:3)
你可以尝试
$xml = '<Family>
<name>aaa</name>
<adults>3</adults>
<kids />
<sub>
<tag>Nice </tag>
<tag>Food </tag>
<tag />
</sub>
</Family>';
$xml = new SimpleXMLElement($xml);
$json = json_encode($xml, JSON_NUMERIC_CHECK);
$json = json_decode($json, true);
var_dump($json); // Before
filterEmptyArray($json); // <------ Filter Empty Array
var_dump($json); // After
在
array
'name' => string 'aaa' (length=3)
'adults' => int 3
'kids' =>
array <------------------- Empty Array
empty
'sub' =>
array
'tag' =>
array
0 => string 'Nice ' (length=5)
1 => string 'Food ' (length=5)
2 =>
array
...
之后
array
'name' => string 'aaa' (length=3)
'adults' => int 3
'kids' => string '' (length=0) <---------- String Conversion
'sub' =>
array
'tag' =>
array
0 => string 'Nice ' (length=5)
1 => string 'Food ' (length=5)
2 => string '' (length=0) <---------- Supports Recursion (2nd level)
使用的功能
function filterEmptyArray(array &$a) {
foreach ( $a as $k => &$v ) {
if (empty($v))
$a[$k] = "";
else
is_array($v) AND filterEmptyArray($v);
}
}
答案 1 :(得分:0)
我认为上面的函数filterEmptyArray()需要添加它才能删除零作为值。 例如。 0也将成为''
if (empty($v) && is_array($v))
$a[$k] = "";
}