2010-05-18 8 views
32

Liste kann ich bitte, lassen Sie mich wissen, ich muss alphabetisch (A-Z) Char zu drucken/Excel-Zellen zu verwalten. Gibt es eine PHP-Funktion, um Alphabetisch aufzulisten?Der beste Weg, um alphabetisch (A-Z) mit PHP

ich führen müssen als

A1 
B1 
C1 
D1 
... 
... 
... 

ODER

A 
B 
C 
... 
... 

Antwort

92

Sie können entweder tun:

foreach (range('A', 'Z') as $char) { 
    echo $char . "\n"; 
} 

Oder:

for ($char = 'A'; $char <= 'Z'; $char++) { 
    echo $char . "\n"; 
} 
+2

Ist das möglich, dass mehr als Z. Das ist A, B, ..., Z, AA, AB, AC, ... –

+0

@VeckHsiao nur interlaced Loops verwenden. –

12

range() Briefe seit PHP 4.1 unterstützt, so können Sie dies tun:

$azRange = range('A', 'Z'); 
foreach ($azRange as $letter) 
{ 
    print("$letter\n"); 
} 
2

Ich glaube, Sie die range function verwenden sollten :

$a=range("A","Z"); 
foreach($a as $char) 
    echo $char."\n"; 
1

Dieses:

$range = range("A", "Z"); 
for ($i=1; i<=100; i++) { 
    foreach ($range as $letter) { 
     print("$letter$i\n"); 
    } 
} 

druckt Sie alle Kombinationen:
A1
B1
C1
... ...
... ...
V100
W100
Z100

Ändern Sie die Bereiche entsprechend Ihren Anforderungen.

0

Wenn Sie sich für einen umfassenden Satz von Excel-Funktionalität, dann nehmen Sie einen Blick auf PHPExcel suchen, die eine Menge von Methoden liefert zum Manipulieren von Zellenadressen und -bereichen sowie Lesen/Schreiben für Excel und verschiedene andere Dateiformate für Tabellenkalkulation

2

Hier ist mein Code für HTML mit PHP-Code, und es funktioniert gut

for($i = 'a' ; $i <= 'z' ; $i++){ 
echo $i. "<br />"; } 
+0

Glauben Sie es oder nicht, das funktioniert tatsächlich für mich, da ich Buchstaben wie in diesem Fall um 1 erhöhen muss. Vielen Dank! –

1

Sie können es auf diese Weise auch tun: ASCII-Bereich hier verwendet.

for($i = 65 ; $i<=90; $i++) 
{ 
    echo chr($i); 
} 
0

Dieser Code für die Anzeige A, B, ..., ZY, ZZ.

function print_char($end_no=90, $start_no=65, $prefix_no=0) 
{ $vasant=''; 
    if($prefix_no==0) 
    { 
     for($set=$start_no; $set<=$end_no; $set++) 
     { 
      $vasant.=(chr($prefix_no).chr($set)).', '; 
     } 
    } 
    else 
    { 
     for($set=$start_no; $set<=90; $set++) 
     { 
      $vasant.=(chr($set)).', '; 
     } 
     for($pre_loop=65; $pre_loop<=$prefix_no; $pre_loop++) 
     { 
      for($set=$start_no; $set<=90; $set++) 
      { 
       if($set>=$end_no && $pre_loop==$prefix_no) 
       { 
        $vasant.=(chr($pre_loop).chr($set)).'. '; 
        break; 
       } 
       else 
       { 
        $vasant.=(chr($pre_loop).chr($set)).', '; 
       } 
      } 
     } 
    } 
    return $vasant; 
} 


$show=print_char(90,65,90); 
echo $show; 
1

Dieser Code ergibt Ihre Anforderungen ....

<?php 
     $x= 'A'; 
      for($i=0;$i<26;$i++) 
      { 
       echo $x."<br/>";//generates A,B,C,D...Z 
       $x++; 
       if($i == 25) 
       { 
        $x = 'A'; 
        $y = '1'; 
        for($j=0;$j<26;$j++) 
        { 
         echo $x.$y."<br />";//generates A1,B1...Z1 
         $x++; 
         if($j == 25) 
         { 
          $x = 'A'; 
          $y++; 
          for($k=0;$k<26;$k++) 
          { 
           echo $x.$y."<br />";//generates A2,B2....Z2 
           $x++; 
          } 
         } 
        } 
       } 
      } 
     ?> 
0
$len = 0; 
for ($char = 'A'; $char <= 'Z'; $char++) { 
    $len++; 
    if ($len == 26) { 
     break; 
    } 
    echo $char; 
} 
+1

Während dieses Code-Snippet die Frage lösen kann, [hilft eine Erklärung] (http://meta.stackexchange.com/questions/114762/explaining-entirely-code-based-answers) wirklich, um die Qualität Ihres Beitrags zu verbessern. Denken Sie daran, dass Sie die Frage für Leser in der Zukunft beantworten, und diese Leute könnten die Gründe für Ihren Codevorschlag nicht kennen. – andreas

+0

** Flaggers/Rezensenten: ** [Für Nur-Code-Antworten wie diese, Downvote, nicht löschen!] (// meta.stackoverflow.com/a/260413/2747593) –

0

Für Excel-Sheet

verwendet rekursive Funktion wie den genauen Bereich von A bis AZ

function myRange($end_column = '', $first_letters = '') { 
    $columns = array(); 
    $length = strlen($end_column); 
    $letters = range('A', 'Z'); 

    // Iterate over 26 letters. 
    foreach ($letters as $letter) { 
     // Paste the $first_letters before the next. 
     $column = $first_letters . $letter; 
     // Add the column to the final array. 
     $columns[] = $column; 
     // If it was the end column that was added, return the columns. 
     if ($column == $end_column) 
      return $columns; 
    } 

    // Add the column children. 
    foreach ($columns as $column) { 
     // Don't itterate if the $end_column was already set in a previous itteration. 
     // Stop iterating if you've reached the maximum character length. 
     if (!in_array($end_column, $columns) && strlen($column) < $length) { 
      $new_columns = myRange($end_column, $column); 
      // Merge the new columns which were created with the final columns array. 
      $columns = array_merge($columns, $new_columns); 
     } 
    } 

    return $columns; 
} 

Anruffunktion zu erhalten.

print_r(myRange('AZ')); 

werden Sie

A B C Ergebnis. . . AX AY AZ

Verwandte Themen