6

我已经使用加载了一个 XML 文件

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

对于大多数提供的 XML,它都可以正常工作。但是,对于 XML 中的某些元素,属性不会转换为“@attributes”数组,而是会从输出中丢失。这是一个示例:

<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 ) ) ) )

如您所见,属性数组已正确添加到大多数元素中,但未正确添加到 FIELD 元素中。我试过重命名它们,但似乎没有什么不同。

编辑:我还应该补充一点,我已经尝试用 FIELDS 标签包围 FIELD 标签,但也无济于事。

编辑:

我极大地简化了 XML,但它仍然不返回 anny 属性:

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

产生:

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

2 回答 2

8

属性是可访问的,例如:

$obj = simplexml_load_string($xml);

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

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

于 2012-04-20T14:35:43.897 回答
3

抱歉这么久才回来回答这个问题!

正如 MrCode 所建议的,这些属性可以访问的。我的问题在于将 SimpleXML 对象序列化为另一种格式。在 while 对象上使用 printr 或 json_convert 导致属性在报告的情况下不可用。

我在这方面做得还不够深入,无法找到基于代码的解决方法来打印或转换这些对象(包括有问题的情况),我只是将其作为 XML 数据的一部分来解决:

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

将此额外级别添加到层次结构中会导致属性保留在顶层,并且文本值在子级别正确可用。

于 2012-06-26T08:31:30.853 回答