问题:如何在数组中的每个用户名上显示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条,它们据说不会被显示,如何删除它们?
解决方法:
您的问题是您没有重置$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);