我有一个XML文件,其中一些标签偶尔可能是空的.当我使用PHP读取此文件并使用json_encode对其进行编码时,JSON会将所有空标记转换为空对象,而我更喜欢它们 – 空字符串.停止/避免此转换的最佳方法是什么?
编辑:
我不想从XML中删除这些标记,因为我没有特定标记的XML条目和此标记为空的XML条目之间存在差异.
编辑2:
样本输入:
aaa
3
孩子标签是空的
我想得到编码结果
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;
解决方法:
你可以试试
$xml = '
aaa
3
Nice
Food
';
$xml = new SimpleXMLElement($xml);
$json = json_encode($xml, JSON_NUMERIC_CHECK);
$json = json_decode($json, true);
var_dump($json); // Before
filterEmptyArray($json); //
var_dump($json); // After
之前
array
'name' => string 'aaa' (length=3)
'adults' => int 3
'kids' =>
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)
'sub' =>
array
'tag' =>
array
0 => string 'Nice ' (length=5)
1 => string 'Food ' (length=5)
2 => string '' (length=0)
使用的功能
function filterEmptyArray(array &$a) {
foreach ( $a as $k => &$v ) {
if (empty($v))
$a[$k] = "";
else
is_array($v) AND filterEmptyArray($v);
}
}
标签:json,php,xml
来源: https://codeday.me/bug/20190629/1331131.html