Mysql
 sql >> Base de données >  >> RDS >> Mysql

Imprimer les résultats d'une requête SELECT sous forme de texte préformaté en PHP ?

sprintf est votre ami, si vous devez avoir une sortie à largeur fixe non-HTML.

Heure d'arrivée :

//id: integer, max width 10
//code: string max width 2

$divider=sprintf("+%-10s+%-13s+",'-','-');

$lines[]=$divider;
$lines[]=sprintf("|%10s|%13s|",'id','countryCode'); //header
$lines[]=$divider;

while($line=$records->fetch_assoc()) {
    //store the formatted output
    $lines[]=sprintf("| %10u | %2.2s |", $line['id'],$line['code']);
}
$table=implode("\n",$lines);
echo $table;

Si vous souhaitez imprimer immédiatement au lieu de stocker les résultats, utilisez printf à la place - même syntaxe. Il y a un tutoriel PHP (s)printf raisonnable ici .