5

以下のコードを使用して、Web サイトフォームデータベースの画像と名前を表示しています。

<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
4

3 に答える 3

8

配列の並べ替えを使用して、配列を並べ替えることができます。あなたの場合、私は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 が欠落していることに注意してください。

于 2013-01-08T07:59:27.783 に答える
3

これは、@Hugo Delsing の回答を修正したものです。

私は自分のブランドをこのようにグループ化できるようにする必要がありましたが、コードのバグの 1 つは、iForce Nutrition と Inner Armor と言うと、文字の大文字と小文字が原因で、これらが 2 つの別々のグループにグループ化されるという事実でした.

私が行った変更
完全にアルファベット順だったので、最初の文字だけでした 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

于 2013-09-16T19:02:38.953 に答える
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>";
    }
于 2015-08-05T12:29:20.100 に答える