在PHP中将SELECT查询的结果打印为预先格式化的文本?

时间:2010-04-14 16:56:00

标签: php mysql

我正在寻找一种简单快捷的方法,将PHP中的MySQL SELECT查询结果打印为预先格式化的文本。我想要的是能够将查询对象传递给函数并获取记录集的打印输出,就像MySQL客户端在运行SELECT语句时所做的命令行一样。

这是我希望它看起来的一个例子(即ASCII):

+----+-------------+
| id | countryCode |
+----+-------------+
|  1 | ES          |
|  2 | AN          |
|  3 | AF          |
|  4 | AX          |
|  5 | AL          |
|  6 | DZ          |
|  7 | AS          |
|  8 | AD          |
|  9 | AO          |
| 10 | AI          |
+----+-------------+

它基本上是一个通用的导入脚本,我正在进行SELECT查询,并希望将结果显示给用户进行确认。

2 个答案:

答案 0 :(得分:3)

sprintf是您的朋友,如果您必须拥有非HTML固定宽度输出。

ETA:

//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;

如果您想立即打印而不是存储结果,请使用printf代替相同的语法。有一个合理的PHP(s)printf教程here

答案 1 :(得分:2)

function formatResults($cols, $rows) {
    echo'<table>';
    echo '<tr>';

    foreach ($cols as $v) {
        echo '<th>' . $v['field'] . '</th>';
    }
    echo '</tr>';

    foreach ($rows as $sRow) {
        echo '<tr>';

        foreach ($sRow as $v) {
            echo "<td>$v</td>";
        }

        echo '</tr>';
    }

    echo '</table>';
}

$qry = $pdo->query('DESCRIBE table');
$cols = $qry->fetchAll(PDO::FETCH_ASSOC);

$pdo->query('SELECT * FROM table');
$rows = $qry->fetchAll(PDO::FETCH_ASSOC);

formatResults($cols, $rows);

未经测试但应该可以使用。

修改:错过了['field']索引;)