问题:如何在数组中的每个用户名上显示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条,它们据说不会被显示,如何删除它们?
答案 0 :(得分:6)
shuffle($friendsArray);
$rand = array_slice($friendsArray, 0, 15);
答案 1 :(得分:4)
您的问题是,您没有重置$friendsArray
,只是用以下内容覆盖某些键:
$friendsArray[$c] = "'".mysql_real_escape_string($friendsArray[$c])."'";
以下是完整的,经过纠正的代码,借用零公里:
shuffle($friendsArray);
$rand = array_slice($friendsArray, 0, 15);
foreach($rand as $friend) {
$sql_output[] = "'".mysql_real_escape_string($friend)."'";
}
$sql_output = join(', ',$sql_output);
答案 2 :(得分: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)