2013-04-25 53 views
13

比方说,我有一些源这个输出,我没有访问原始PHP创建数组:重新创建print_r的输出原始的PHP阵列

Array 
(
    [products] => Array 
     (
      [name] => Arduino Nano Version 3.0 mit ATMEGA328P 
      [id] => 10005 
     ) 

    [listings] => Array 
     (
      [category] => 
      [title] => This is the first line 
This is the second line 
      [subtitle] => This is the first subtitle 
This is the second subtitle 
      [price] => 24.95 
      [quantity] => 
      [stock] => 
      [shipping_method] => Slow and cheap 
      [condition] => New 
      [defects] => 
     ) 

    [table_count] => 2 
    [tables] => Array 
     (
      [0] => products 
      [1] => listings 
     ) 

) 

现在我想输入的数据和有一个算法重新创建它正在打印的原始数组,然后我可以将它用于我自己的应用程序。

目前我正在考虑sub_str()和正则表达式来提取数据并将其正确放置。在我进一步讨论之前,是否有一种更简单的方法,通过已经编写的代码或php插件为我做到了这一点?

+0

显示你试过的东西... – michi 2013-04-25 22:55:34

+0

目前我正在考虑一个sub_str()和正则表达式来提取数据并将其正确放置。在我进一步探讨之前,有没有更简单的方法,通过已经编写的代码或者php插件为我做到了这一点? – Dan 2013-04-25 22:56:08

+3

这是[var_export](http://www.php.net/var_export)的用途,而不是print_r。 – 2013-04-25 23:00:34

回答

19
function print_r_reverse($in) { 
    $lines = explode("\n", trim($in)); 
    if (trim($lines[0]) != 'Array') { 
     // bottomed out to something that isn't an array 
     return $in; 
    } else { 
     // this is an array, lets parse it 
     if (preg_match("/(\s{5,})\(/", $lines[1], $match)) { 
      // this is a tested array/recursive call to this function 
      // take a set of spaces off the beginning 
      $spaces = $match[1]; 
      $spaces_length = strlen($spaces); 
      $lines_total = count($lines); 
      for ($i = 0; $i < $lines_total; $i++) { 
       if (substr($lines[$i], 0, $spaces_length) == $spaces) { 
        $lines[$i] = substr($lines[$i], $spaces_length); 
       } 
      } 
     } 
     array_shift($lines); // Array 
     array_shift($lines); // (
     array_pop($lines); //) 
     $in = implode("\n", $lines); 
     // make sure we only match stuff with 4 preceding spaces (stuff for this array and not a nested one) 
     preg_match_all("/^\s{4}\[(.+?)\] \=\> /m", $in, $matches, PREG_OFFSET_CAPTURE | PREG_SET_ORDER); 
     $pos = array(); 
     $previous_key = ''; 
     $in_length = strlen($in); 
     // store the following in $pos: 
     // array with key = key of the parsed array's item 
     // value = array(start position in $in, $end position in $in) 
     foreach ($matches as $match) { 
      $key = $match[1][0]; 
      $start = $match[0][1] + strlen($match[0][0]); 
      $pos[$key] = array($start, $in_length); 
      if ($previous_key != '') $pos[$previous_key][1] = $match[0][1] - 1; 
      $previous_key = $key; 
     } 
     $ret = array(); 
     foreach ($pos as $key => $where) { 
      // recursively see if the parsed out value is an array too 
      $ret[$key] = print_r_reverse(substr($in, $where[0], $where[1] - $where[0])); 
     } 
     return $ret; 
    } 
} 

不是我的代码,发现这里的评论:print_r “马特”是主人

0

我也摸索出了解决您的问题,因为它是在这里重现问题的一个非常有用的工具堆栈溢出。我的来源位于:https://github.com/etalon/aprp

我做了一点不同:在你的字符串中,你不需要换行符,所以我走过了字符。一个缺点:如果你的数组中有括号或括号,它将不起作用。