将带有分隔值的XML项处理到PHP数组中

时间:2016-06-06 15:22:13

标签: php arrays xml wordpress wpallimport

我正在尝试将XML项目处理成PHP数组并简单地返回它。

然而,我得到"数组到字符串转换"作为第3行的错误。

PHP代码

function processPlayers($players) { // paramater is the XML item
    $playerGUIDS = array();
    $playerGUIDArray = explode(";", $players); // CREATE ARRAY FROM STRING WHICH HAVE A ; DELIMINATER

    foreach($playerGUIDArray as $player) {
        $playerGUIDS[] = $player;   
    }
    return $playerGUIDS;
}

XML项目

<playguid>DC242003;BY523643</playguid>

我使用WP ALL Import作为插件,因此我将自定义字段数据值指定为

[processPlayers({playguid[1]})]

见这里:

http://www.wpallimport.com/2015/10/wp-all-export-1-1-1-function-editor/ http://www.wpallimport.com/documentation/advanced/execute-php/

我的理想输出如下(这是WordPress数据库中的元数据形式)。

a:2:{i:0;s:8:"JC745819";i:1;s:8:"JB705789";}

2 个答案:

答案 0 :(得分:0)

您收到错误,因为WPAllImport尝试将此值插入数据库。因此,您必须返回函数string值,而不是数组。在您的情况下,序列化:

function processPlayers($players) {
    return serialize(explode(";", $players));
}

答案 1 :(得分:0)

在将多个XML项目解析为一个数组时,我遇到了一个密切相关的案例。由于这是该主题排名最高的搜索结果之一,因此我认为以下内容可能会对其他人有所帮助:

WP All Import不会将数组值传递给自定义PHP函数。如果您的输入元素不是字符串,而是例如XML子元素列表,那么如果您尝试执行以下操作,则WP All Import将传递一个空字符串:

<parents>
  <parent>...</parent>
  <parent>...</parent>
  <parent>...</parent>
  ...
</parents>
[IF(has_special_children({parents[1]}))]

<h2>My Conditional Header</h2>

{parents[1]/parent[8]}

{parents[1]/parent[12]}

{parents[1]/parent[13]}

[ENDIF]
<?php
function has_special_children($parent) {
  var_dump(gettype($parent));  // outputs: string
  var_dump($parent);           // outputs: string ""
  return $parent[8] || $parent[12] || $parent[13];
}
?>

在PHP函数中,$parent在传递带有子元素的XML元素时始终为空字符串。

解决方案

您可以在PHP中使用variadic function来传递感兴趣的元素并单独检查它们:

[IF(wpai_has_any_value({parents[1]/parent[8]}, {parents[1]/parent[12]}, {parents[1]/parent[13]}))]

<h2>My Conditional Header</h2>

{parents[1]/parent[8]}

{parents[1]/parent[12]}

{parents[1]/parent[13]}

[ENDIF]
<?php
function wpai_has_any_value(...$values) {
  return (bool) array_filter($values);
}
?>