我使用foreach循环从我的数据库中回显出一些值,如果有意义,我需要从最后一个循环中删除最后一个逗号。
我的循环很简单,如下所示
foreach($results as $result){
echo $result->name.',';
}
哪个回声
result,result,result,result,
我只需要杀掉那个讨厌的最后一个逗号。
任何帮助都会很棒:)
干杯
答案 0 :(得分:104)
更好:
$resultstr = array();
foreach ($results as $result) {
$resultstr[] = $result->name;
}
echo implode(",",$resultstr);
答案 1 :(得分:22)
|
$s = '';
foreach ($results as $result) {
if ($s) $s .= '|';
$s .= $result;
}
echo $s;
|
$s = '';
$n = count($results);
foreach ($results as $i => $result) {
$s .= $result;
if (($i+1) != $n) $s .= '|';
}
echo $s;
$s = array();
foreach ($results as $result) {
$s[] = $result;
}
echo implode('|', $s);
|
(或rtrim
它)$s = '';
foreach ($results as $result) {
$s .= $result . '|';
}
echo substr($s, 0, -1);
# echo rtrim($s, '|');
array_map()
echo implode('|', array_map(function($result) { return $result; }, $results));
答案 2 :(得分:12)
$result_names = '';
foreach($results as $result){
$result_names .= $result->name.',';
}
echo rtrim($result_names, ',');
答案 3 :(得分:1)
$arraySize = count($results);
for($i=0; $i<$arraySize; $i++)
{
$comma = ($i<$arraySize) ? ", " : "";
echo $results[$i]->name.$comma;
}
答案 4 :(得分:1)
不是很漂亮,但也有效:
$first=true;
foreach($results as $result){
if(!$first) { echo ', '; }
$first=false;
echo $result->name;
}
答案 5 :(得分:1)
$string = "";
while ($row = mysql_fetch_array($result)) {
$string .= $name . ', ';
}
echo substr($string, 0, strlen($string) - 2);
答案 6 :(得分:1)
我最近也遇到了类似的问题。我通过使用增量变量$ i对其进行了修复,将其初始化为0,然后使其在foreach循环内递增。如果$ i计数器小于数组/变量的sizeof()运算符,则在该循环中放置一个if,否则,在echo语句中包含一个逗号。
我不知道这是否可以解决您的问题,但这对我有帮助。我意识到这个问题已有很长的历史了,但是希望可以对其他人有所帮助。我对PHP还是很陌生,所以我不太理解我之前给出的许多答案,尽管它们很有见地,尤其是内向的。
$i=0;
foreach ($results as $result) {
$i++;
if(sizeof($results) > $i) {
echo $result . ", ";
} else {
echo $result;
}
}
答案 7 :(得分:1)
在现代PHP中,array_column()
将允许您隔离对象数组中的一列数据。
代码:(Demo)
$results = [
(object)['name' => 'A'],
(object)['name' => 'B'],
(object)['name' => 'C']
];
echo implode(',', array_column($results, 'name'));
输出:
A,B,C
也就是说,由于您要迭代结果集,因此最好在sql中调用CONCAT()
函数,以便将值已加入单个值结果集中,从而为您提供更好的服务。
答案 8 :(得分:0)
<?php
$return = array(any array)
$len = count($return);
$str = '';
$i = 1;
foreach($return as $key=>$value)
{
$str .= '<a href='.$value['cat_url'].'>'.$value['cat_title'].'</a>';
if($len > $i)
{
$str .= ',';
$i = $i+1;
}
}
echo $str;
?>
答案 9 :(得分:0)
此处end($array)
相当容易:
foreach($results as $result){
echo $result->name . (end($results) ? '' : ',');
}
reference此处。
另一个聪明的方法是:
foreach($results as $result){
echo ($passed ? ',' : '') . $result->name;
$passed = true;
}
在这种情况下,第一个循环$passed
为NULL
且,
无法打印。
答案 10 :(得分:0)
<?php
$i = 1;
$count = count( $results );
foreach( $results as $result ) {
echo $result->name;
if ( $i < $count ) echo ", ";
++$i;
}
?>
答案 11 :(得分:0)
我知道这是一个旧线程,但最近出现了这个问题,我想我会分享我使用 next() 的替代、更简洁的处理方式。
$array = array("A thing", "A whatsit", "eighty flange oscillators");
foreach( $array as $value ){
echo $value;
$nxt = next($array);
if($nxt) echo ", "; // commas between each item in the list
else echo ". And that's it."; // no comma after the last item.
}
// outputs:
// A thing, A whatsit, eighty flange oscillators. And that's it.
答案 12 :(得分:-1)
我必须这么做,因为我总是试图将数字输入到jplot中,我发现更容易将逗号放在循环的前面,如下所示:
foreach($arrayitem as $k){ $string = $string.",".$k;
}
然后使用substr删除第一个字符(逗号),如果你知道你的字符串长的猜测会有帮助,我不确定substr max字符的限制是什么。
echo substr($a,1,10000000);
希望这会有所帮助。
答案 13 :(得分:-1)
$a[0] = 'John Doe';
$a[1] = 'Jason statham';
$a[2] = 'Thomas Anderson';
$size = count($a);
foreach($a as $key=>$name){
$result .= $name;
if($size > $key+1) $result .=', ';
}
echo $result;
答案 14 :(得分:-1)
这是我通常的工作,在忽略第一个循环的同时,在项目之前而不是之后添加逗号。
$i = 0;
$string = '';
foreach($array as $item){
$string .= ($i++ ? ',' : '').$item;
}
答案 15 :(得分:-9)
首先使用输出缓冲获取所有输出。然后,修剪逗号并显示它。所以,这样做:
ob_start();
foreach($results as $result)
{
echo $result->name.',';
}
$output = ob_get_clean();
echo rtrim($output, ',');
输出缓冲方法有助于内部循环非常大(OP为了简洁而在此处发布),然后在不改变循环内部的情况下使用OB更容易。