如何使用php循环并从数据库中获取序列化值
我正在开发一家比萨餐厅的电子商务,现在我正在尝试获取比萨的尺寸(熟悉)和配料(Pernil dol)�, 美国银行�, (意式)先前订购的比萨饼。我想要获取的数据(本段中的斜体值)将从数据库中序列化:如何使用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
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>');
}