组数组以字母顺序PHP结果

时间:2013-01-08 07:53:09

标签: php foreach group-by

我正在使用以下代码来显示Image&网站名称来自数据库。

<fieldset>  
    <h1>A</h1>          
    <ul>
        <?php foreach ($records as $key) { ?>
        <li class="siteli"> <a href="#" class="add">        
            <div id="site-icon"><img src="<?php echo $key->site_img; ?>" width="16" height=""></div>
            <p id="text-site"> <?php echo $key->site_name; ?></p>
        </li>
        <?php } ?>
    </ul>
</fieldset>

现在我试图通过添加A,B,C等作为标题按字母顺序对此结果进行分组。

实施例,

A    
Amazon     
Aol    
Aol Mail

B    
Bing     
Bogger

3 个答案:

答案 0 :(得分:6)

您可以使用array sorting对数组进行排序。在您的情况下,我会选择sort()

现在,我将使用前面的字母显示链接:

<?php
$records = ['Aaaaa', 'Aaaa2', 'bbb', 'bbb2', 'Dddd'];
$lastChar = '';
sort($records, SORT_STRING | SORT_FLAG_CASE); //the flags are needed. Without the `Ddd` will come before `bbb`.
//Available from version 5.4. If you have an earlier version (4+) you can try natcasesort()

foreach($records as $val) {
  $char = $val[0]; //first char

  if ($char !== $lastChar) {
    if ($lastChar !== '')
      echo '<br>';

    echo strtoupper($char).'<br>'; //print A / B / C etc
    $lastChar = $char;
  }

 echo $val.'<br>';
}
?>

这将输出类似

的内容
A
Aaaa2
Aaaaa

B
bbb
bbb2

D
Dddd

请注意,C缺失,因为没有以C开头的单词。

答案 1 :(得分:2)

这是对@Hugo Delsing的回答的修改。

我需要能够像这样将我的品牌组合在一起,但代码中的一个错误是,如果我说iForce Nutrition和Inner Armor,它会将这些组合成两个独立的组,因为这是一个字母案例。

我所做的改变
因为它是完全按字母顺序排列的,所以它只是通过第一个字母我将SORT_STRING更改为SORT_NATURAL

更改:if($ char!== $ lastChar)if(strtolower($ char)!== strtolower($ lastChar))

<?php
$records = ['FinaFlex', 'iForce Nutrition', 'Inner Armour', 'Dymatize', 'Ultimate    Nutrition'];
$lastChar = '';
sort($records, SORT_NATURAL | SORT_FLAG_CASE); //Allows for a full comparison and will alphabetize correctly.

foreach($records as $val) {
 $char = $val[0]; //first char

  if (strtolower($char) !== strtolower($lastChar)) {
    if ($lastChar !== '')
     echo '<br>';

     echo strtoupper($char).'<br>'; //print A / B / C etc
     $lastChar = $char;
    }

    echo $val.'<br>';
  }
?>

最终输出将是这样的

D
Dymatize

F
FinaFlex

I
iForce Nutrition
Inner Armour

U
Ultimate Nutrition

我希望这对每个人都有所帮助,非常感谢Hugo提供的代码让我确切地知道我需要的位置。

您可以在此处查看我的示例https://hyperionsupps.com/brand-index

答案 2 :(得分:0)

$records = ['FinaFlex', 'iForce Nutrition', 'Inner Armour', 'Dymatize', 'Ultimate    Nutrition'];

    $temp=array();    
    $first_char="";
    for($i=0;$i<count($records);$i++)
    {
        $first_char= strtoupper ($records[$i][0]);             
             if(!in_array($first_char, $temp))
             {
                 echo strtoupper($first_char).'<br>'; //print A / B / C etc                      

             }
             $temp[]=  $first_char;
            echo $records[$i]."<br>";
    }