使用SimpleXML不返回的某些元素属性加载XML(Loading XML using Simpl

2019-09-16 15:45发布

我已加载使用XML文件

simplexml_load_file($filePath,'SimpleXMLElement', LIBXML_NOCDATA);

对于一般的XML提供它工作正常。 然而,对于一些在XML元素的属性不被转换成一个“@属性”阵列,并反而缺少形成输出。 下面是一个示例:

<UI_DEFINITION>
<EDIT_PERMISSION>testPermission</EDIT_PERMISSION>
<DEFAULT_VALUES>
    <display>hidden</display>
    <css_class>generic_css_class</css_class>
    <title>{tag}</title>
    <type>string</type>
    <wrapper_format>{value}</wrapper_format>
    <full_path>false</full_path>
    <mandatory>false</mandatory>
    <edit_permission>testPermission</edit_permission>
    <max_length>0</max_length>
</DEFAULT_VALUES>
<LOOKUPS>
    <DB_LOOKUP name="test3">
        <VIEW>???</VIEW>
        <ID_FIELD>???</ID_FIELD>
        <DESCR_FIELD>???</DESCR_FIELD>
        <ORDER>??? asc</ORDER>
    </DB_LOOKUP>
    <DB_LOOKUP name="test1">
        <VIEW>???</VIEW>
        <ID_FIELD>???</ID_FIELD>
        <DESCR_FIELD>???</DESCR_FIELD>
        <ORDER>??? asc</ORDER>
    </DB_LOOKUP>
</LOOKUPS>
<AREA internal_name="main_details" title="" display="show">
    <FIELD lookup="test1" title="Title">Title</FIELD>
    <FIELD title="Name">Given_Name</FIELD>
    <FIELD title="Mid. Name(s)">Middle_Names</FIELD>
    <FIELD title="Family Name">Family_Name</FIELD>
    <FIELD title="Gender">Gender</FIELD>
    <FIELD title="Born" type="date">Date_of_Birth</FIELD>
    <FIELD max_length="20" title="ID">Unique_Identifier</FIELD>
</AREA>

这使得从print_r的输出如下(我在这就是问题所在位附加​​一个换行符):

SimpleXMLElement Object ( [UI_DEFINITION] => SimpleXMLElement Object ( [EDIT_PERMISSION] => testPermission [DEFAULT_VALUES] => SimpleXMLElement Object ( [display] => hidden [css_class] => generic_css_class [title] => {tag} [type] => string [wrapper_format] => {value} [full_path] => false [mandatory] => false [edit_permission] => testPermission [max_length] => 0 ) [LOOKUPS] => SimpleXMLElement Object ( [DB_LOOKUP] => Array ( [0] => SimpleXMLElement Object ( [@attributes] => Array ( [name] => test3 ) [VIEW] => ??? [ID_FIELD] => ??? [DESCR_FIELD] => ??? [ORDER] => ??? asc ) [1] => SimpleXMLElement Object ( [@attributes] => Array ( [name] => test1 ) [VIEW] => ??? [ID_FIELD] => ??? [DESCR_FIELD] => ??? [ORDER] => ??? asc ) ) ) 
[AREA] => SimpleXMLElement Object ( [@attributes] => Array ( [internal_name] => main_details [title] => [display] => show ) [FIELD] => Array ( [0] => Title [1] => Given_Name [2] => Middle_Names [3] => Family_Name [4] => Gender [5] => Date_of_Birth [6] => Unique_Identifier ) ) ) )

正如你所看到的,属性阵列正确添加到大多数元素,但不是到外地元素。 我试图重新命名他们,这似乎并没有发挥作用。

编辑:我还要补充一点,我已经试过了FIELDS标签周围的字段标识,也无济于事。

编辑:

我巨大的简化了XML,它仍然不返回ANNY属性:

<UI_DEFINITION>
                            <FIELD lookup="test1" title="Title">Title</FIELD>
                    </UI_DEFINITION>

生产:

SimpleXMLElement Object ( [UI_DEFINITION] => SimpleXMLElement Object ( [FIELD] => Title ) )

Answer 1:

该属性是可访问的,例如:

$obj = simplexml_load_string($xml);

foreach($obj->AREA->FIELD as $field)
{
   echo $field->attributes()->title . '<br />';
}

print_r()并不总是显示完整的结构用SimpleXML,但属性是有使用。



Answer 2:

对不起它采取这么久才回来,回答这个问题!

作为MrCode建议,属性可访问的。 我在的SimpleXML的序列化问题对象为另一种格式。 使用while对象printr或json_convert导致不是在报告的病例中可用的属性。

我没有走的不够远到这个发现打印或将这些对象包括有问题的情况下,我只是围绕它曾作为XML数据的一部分,基于代码的解决方法:

<UI_DEFINITION>
        <FIELD lookup="test1" title="Title"><VALUEPATH>Title</VALUEPATH></FIELD>
 </UI_DEFINITION>

Addint这额外的水平进入层次导致在顶层被保存的属性,以及文本值的子级是可用正确。



文章来源: Loading XML using SimpleXML doesn't return attributes on some elements