如何使用php循环并从数据库中获取序列化值

如何使用php循环并从数据库中获取序列化值,php,arrays,serialization,drupal,ubercart,Php,Arrays,Serialization,Drupal,Ubercart,我正在开发一家比萨餐厅的电子商务,现在我正在尝试获取比萨的尺寸(熟悉)和配料(Pernil dol)�, 美国银行�, (意式)先前订购的比萨饼。我想要获取的数据(本段中的斜体值)将从数据库中序列化: a:4:{s:10:"attributes";a:2:{s:6:"Tamany";a:1:{i:3;s:8:"Familiar";}s:11:"Ingredients";a:3:{i:318;s:12:"Pernil dol�";i:270;s:5:"Bac�";i:294;s:8:"Emment

我正在开发一家比萨餐厅的电子商务,现在我正在尝试获取比萨的尺寸(熟悉)和配料(Pernil dol)�, 美国银行�, (意式)先前订购的比萨饼。我想要获取的数据(本段中的斜体值)将从数据库中序列化:

a:4:{s:10:"attributes";a:2:{s:6:"Tamany";a:1:{i:3;s:8:"Familiar";}s:11:"Ingredients";a:3:{i:318;s:12:"Pernil dol�";i:270;s:5:"Bac�";i:294;s:8:"Emmental";}}s:9:"shippable";s:1:"0";s:4:"type";s:5:"pizza";s:6:"module";s:10:"uc_product";}array(4) { ["attributes"]=> array(2) { ["Tamany"]=> array(1) { [3]=> string(8) "Familiar" } ["Ingredients"]=> array(3) { [318]=> string(11) "Pernil dol�" [270]=> string(4) "Bac�" [294]=> string(8) "Emmental" } } ["shippable"]=> string(1) "0" ["type"]=> string(5) "pizza" ["module"]=> string(10) "uc_product" }
我发现了“非序列化”php方法,并尝试了以下方法:

$attr = $row['data']; // data from database
$data = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('$2').':\"$2\";'", $attr); // I did this because I get some errors...
之后,我得到了这个多维数组(更容易理解):

下一步是尝试使用foreach循环循环结果数据,如下所示:

foreach($data['attributes'] as $item)
  {
    print '<ul>';

    foreach($item as $value)
    {
        print_r('<li>' . $value . '</li>');
    }

    print '</ul>';
  }
有人能告诉我如何循环这个数组来获取数据吗? 任何帮助都将非常感谢


向您致意,

我为您创建了这个示例。首先,我声明了一个数组,它模拟了必须解析的数组。然后我循环并输出数组的内容

<?php

$array = array(
    0 => array(
        '0' => 'John Doe',
        '1' => 'john@example.com'
    ),
    1 => array(
        '0' => 'Jane Doe',
        '1' => 'jane@example.com'
    ),
);  

foreach ($array as $key => $value) {

    $thisArray = $array[$key];

    print_r('<ul>');
    foreach ($thisArray as $key2 => $value){
      print_r('<li>'.$thisArray[$key2].'</li>');
    }
    print_r('</ul>');
}
?>

最后,根据@Gregory Hart的回答,我达到了目标。这是在我的特殊情况下使其成为可能的最终代码:

$data = $row['data'];
  $attrib = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('$2').':\"$2\";'", $data);
  $attr = unserialize($attrib);

  foreach ($attr as $key => $value)
  {
      print_r('<ul>');
      $thisArray = $attr[$key];

      foreach ($thisArray as $key2 => $value2)
      {
        print_r('<li>' . $key2 . ': ');
        $thisArray2 = $attr[$key][$key2];

        foreach ($thisArray2 as $key3 => $value3)
        {
          if ($key2 == 'Tamany')
            print_r('<span class="label label-warning">' . utf8_encode($thisArray2[$key3]) . '</span> ');
          if ($key2 == 'Ingredients')
            print_r('<span class="label label-success">' . utf8_encode($thisArray2[$key3]) . '</span> ');
          if ($key2 == 'Salsa')
            print_r('<span class="label label-primary">' . utf8_encode($thisArray2[$key3]) . '</span> ');
        }
        print '</li>';
      }
      print_r('</ul>');
  }
$data=$row['data'];
$attrib=preg\u replace(“!s:(\d+):”(.*?);!e',“'s:”.strlen(“$2”):\“$2\”;”,$data);
$attr=unserialize($attrib);
foreach($attr as$key=>$value)
{
印刷品(“
    ”); $thisArray=$attr[$key]; foreach($key2=>$value2的此数组) { 打印(“
  • ”.$key2.:”); $thisArray2=$attr[$key][$key2]; foreach($thisaray2为$key3=>$value3) { 如果($key2=='Tamany') 打印('.utf8_编码($thisArray2[$key3])); 如果($key2==‘成分’) 打印('.utf8_编码($thisArray2[$key3])); 如果($key2=='Salsa') 打印('.utf8_编码($thisArray2[$key3])); } 打印“
  • ”; } 打印(“
”); }

谢谢你的帮助

您能告诉我们您在mysql表或列中使用了什么编码,以及如何存储序列化数据吗。似乎编码产生了问题,我不知道数据库中的数据是如何编码的。我只知道Ubercart,Drupal7的电子商务模块就是这样做的。
<?php

$array = array(
    0 => array(
        '0' => 'John Doe',
        '1' => 'john@example.com'
    ),
    1 => array(
        '0' => 'Jane Doe',
        '1' => 'jane@example.com'
    ),
);  

foreach ($array as $key => $value) {

    $thisArray = $array[$key];

    print_r('<ul>');
    foreach ($thisArray as $key2 => $value){
      print_r('<li>'.$thisArray[$key2].'</li>');
    }
    print_r('</ul>');
}
?>
$data = $row['data'];
  $attrib = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('$2').':\"$2\";'", $data);
  $attr = unserialize($attrib);

  foreach ($attr as $key => $value)
  {
      print_r('<ul>');
      $thisArray = $attr[$key];

      foreach ($thisArray as $key2 => $value2)
      {
        print_r('<li>' . $key2 . ': ');
        $thisArray2 = $attr[$key][$key2];

        foreach ($thisArray2 as $key3 => $value3)
        {
          if ($key2 == 'Tamany')
            print_r('<span class="label label-warning">' . utf8_encode($thisArray2[$key3]) . '</span> ');
          if ($key2 == 'Ingredients')
            print_r('<span class="label label-success">' . utf8_encode($thisArray2[$key3]) . '</span> ');
          if ($key2 == 'Salsa')
            print_r('<span class="label label-primary">' . utf8_encode($thisArray2[$key3]) . '</span> ');
        }
        print '</li>';
      }
      print_r('</ul>');
  }