混淆的foreach循环显示数组值

3
问题:如何在数组中显示15个带单引号的随机用户名?
代码:
$friendsArray = array("zac1987", "peter", "micellelimmeizheng1152013142",.....);
$randomfriends = array_rand($friendsArray, 15); //random select 15 usernames

foreach($randomfriends as $c => $friend){ //wrap each username in a single quote
    $friendsArray[$c] = "'".mysql_real_escape_string($friendsArray[$c])."'";
}

$friendsArray2 = join(', ',$friendsArray);
echo $friendsArray2;

输出:

'hh', 'gg', 'ff', 'dd', 'ss', 'aa', 'oo', 'ii', 'uu', 'yy', 'tt', 'rr', 'ee', 'ww', 'qq', micellelimmeizheng1152013142, vv, bb

从输出中可以明显看出问题。micellelimmeizheng1152013142、vv和bb是第16、17和18个条目,没有单引号,它们应该不显示,如何删除它们?


foreach($randomfriends as $c => $friend) -- 你知道 array_rand 只返回键名,对吧? => $friend 这个部分有点无意义。 - Brad Christie
3个回答

6
shuffle($friendsArray);
$rand = array_slice($friendsArray, 0, 15);

以下是样例代码:http://ideone.com/hjrcY


我已经有了 $randomfriends = array_rand($friendsArray, 15); 并且它运行得很好。如果我有1000条记录,需要从中选择15条,哪些代码会更好/更快? - zac1987
1
@zac1987:如果你有1000条记录,最好在数据库中对它们进行排序/洗牌,然后只获取你不需要的那些。 - zerkms
1
@zac1987:这是个笑话吗?你认为 ORDER BY RAND() 会导致性能问题,但在 PHP 中获取 所有 数据并随机排序 - 不会有问题吗?o_O - zerkms
@zac1987:如果用PHP实现相同的功能,那么你的说法就是错误的,因为它比PHP更加轻量级。此外,1000行数据很容易放入内存中并立即进行排序。 - zerkms
“Order BY RAND() 从660,000条记录中随机选择需要2.15秒”,而你在PHP中仅对1000行进行洗牌。因此,将其与从数据库中选择并洗牌1000行进行比较。” - zerkms
显示剩余7条评论

4

您的问题在于您没有重置$friendsArray,而是仅覆盖了某些键:

$friendsArray[$c] = "'".mysql_real_escape_string($friendsArray[$c])."'";

以下是您的完整和更正后的代码,借鉴了zerkms的方法:

shuffle($friendsArray);
$rand = array_slice($friendsArray, 0, 15);

foreach($rand as $friend) {
    $sql_output[] = "'".mysql_real_escape_string($friend)."'";
}

$sql_output = join(', ',$sql_output);

你所说的zmayte是谁? :P - alex
@Jason McCreary。哇!它起作用了!非常感谢你。我认为函数array_rand()让事情变得复杂了。 - zac1987
@zac1987,没问题。在这种情况下,我同意zermks提供的代码比array_rand()更直观,因为它返回键。但无论如何,如果你将sql输出存储在一个单独的数组中,你原来的代码也是可以工作的。 - Jason McCreary

0
如果您需要删除引号后面的所有内容,可以使用以下代码:
<?php

$sample = "'hh', 'gg', 'ff', 'dd', 'ss', 'aa', 'oo', 'ii', 'uu', 'yy', 'tt', 'rr', 'ee', 'ww', 'qq', micellelimmeizheng1152013142, vv, bb";
echo substr($sample, 0, strripos($sample, "'")+1)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接