我构建了一个多维数组来存储一些值,我能够删除重复项。
我现在要做的是构建一个for或foreach循环来按键回放子数组值,如[0],[1]等,因为它似乎已经把它们放在了很好的行中。 Print_r完全按照我的需要显示数据,但我需要迭代为每个集合构建一些表单按钮。
我使用我发现的函数从多维数组生成唯一条目,如下所示:
function multi_unique($array) {
foreach ($array as $k=>$na)
$new[$k] = serialize($na);
$uniq = array_unique($new);
foreach($uniq as $k=>$ser)
$new1[$k] = unserialize($ser);
return ($new1);
}
初始化数组:
$unique_array = array(
'username'=>array(),
'user_id'=>array(),
'weeknumber'=>array()
);
在while循环中构建数组:
while($row = mysql_fetch_array($query))
{
$unique_array[] = array('username'=>$row['username'], 'user_id'=>$row['user_id'], 'weeknumber'=>$row['weeknumber']);
}
最后,我需要确保数组值是唯一的(由于数据库和查询限制存在重复条目),在我有while循环后:
print_r(multi_unique($unique_array));
在print_r页面上生成这样的输出,这是从数据库动态生成的,删除了重复的条目:
Array ( [username] => Array ( ) [0] => Array ( [username] => username1 [user_id] => 58 [weeknumber] => 1 ) [1] => Array ( [username] => username2 [user_id] => 21 [weeknumber] => 1 ) [3] => Array ( [username] => username3 [user_id] => 24 [weeknumber] => 1 )
就像我说的,一切都在游戏中进入阵列,我只需要一个好方法再次拉出所有内容,我需要用户名,user_id和weeknumber来循环回调。
感谢任何帮助!
是的,我知道mysql已被弃用,但现在改变现在已太晚了+我正在努力解决现有代码问题。
答案 0 :(得分:2)
你可以循环遍历数组,循环的每次迭代都是unique_array
foreach($unique_array as $row){
// Format this as desired
echo $row['username'] . $row['user_id'] . $row['weeknumber'];
}
答案 1 :(得分:0)
您的初始化代码不正确,应该是:
$unique_array = array();
要解决所有问题,请使用:
foreach ($unique_array as $user) {
echo "Username: " . $user['username'] . "\n";
echo "UserID: " . $user['user_id'] . "\n";
echo "Week Number: " . $user['weeknumber'] . "\n";
echo "\n";
}