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

How to loop and get serialized values from database with php

我正在开发比萨餐厅的电子商务,现在我正在尝试获取大小(熟悉)和配料(Pernil dol�, Bac �, Emmental) 之前订购的披萨。我想要获取的数据(本段中的 italic 值)从数据库序列化:

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" }

我发现了 'unserialized' php 方法并尝试了这个:

$attr = $row['data']; // data from database
$data = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('').':\"\";'", $attr); // I did this because I get some errors...

在我这样做之后,我得到了这个多维数组(更具人类可读性):

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" }

下一步是尝试使用 foreach 循环循环生成的数据,如下所示:

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

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

    print '</ul>';
  }

我是一名 php 初学者 PHP 开发人员,我不知道如何循环这个数组以获得我需要的值。我收到此错误:

Warning: Invalid argument supplied for foreach() in /home/my_host/public_html/dev.mysite.com/inc/file.php on line 79

谁能告诉我如何循环这个数组来获取数据? 非常非常感谢任何帮助。

此致,

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

<?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('').':\"\";'", $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_unserialize = unserialize($row->data);
    foreach ($data_unserialize as $data_key => $data_value) {
    if($data_key =='size')
{

$thisArray = $data_unserialize[$data_key ];

   foreach ($thisArray as $key2 => $value2){

   if($key2=='attributes')
   {
    switch ($value2) 
    {
      case "Pernil dol�":
         echo'Pernil dol �';
        break;
      case "Emmental":
        echo'Emmental';
        break;
 
      default:
        echo 'Nothing';
     }
    }

   }
   }
                                         
  }

注意:- 并删除中断;从 switch 语句显示所有成分。