0

PHP を使用して、MySQL データまたは静的テーブル データを csv、Excel、JSON、MySQL などに変換できますが、テーブル データを PDF や JPG/PNG などの他のフォーマット/スタイル形式に変換できる便利な変換スクリプトまたはツールはありますかPHP GD ライブラリなどを使用していますか?

4

3 に答える 3

1

以前にこれを使用して、HTML テーブルを PDF に変換しました。MySQL クエリからテーブルを生成しました。

于 2009-05-13T04:01:44.650 に答える
0

Excel にエクスポートするには、次のコードを使用します。

<?php

/*  Define our Database and Table Info */


$username="";
$password="";
$database="";
$table="";


mysql_connect(localhost,$username,$password);
@mysql_select_db($database) or die( "Unable to select database");
$select = "SELECT * FROM $table";                
$export = mysql_query($select);
$fields = mysql_num_fields($export);

for ($i = 0; $i < $fields; $i++) {
    $header .= mysql_field_name($export, $i) . "\t";
}

while($row = mysql_fetch_row($export)) {
    $line = '';
    foreach($row as $value) {                                            
        if ((!isset($value)) OR ($value == "")) {
            $value = "\t";
        } else {
            $value = str_replace('"', '""', $value);
            $value = '"' . $value . '"' . "\t";
        }
        $line .= $value;
    }
    $data .= trim($line)."\n";
}
$data = str_replace("\r","",$data);

if ($data == "") {
    $data = "\n(0) Records Found!\n";                        
}

header("Content-type: application/x-msdownload");
header("Content-Disposition: attachment; filename=mailinglist.xls");
header("Pragma: no-cache");
header("Expires: 0");
print "$header\n$data"; 
?> 

これをどのように含めるかに注意してください。ヘッダーを使用してファイル情報を送信し、ダウンロードを強制します。これにより、これらのヘッダーが送信される前に空白を含めることができなくなります。そうしないと、エラーがスローされる可能性があります。私は通常、このリンクを新しいウィンドウとして開いて、何も起こらないようにしています... これも非常に基本的なスクリプトであり、大幅に拡張できます。お役に立てれば!

于 2009-05-13T04:15:24.053 に答える
0
<?php  

/  Define our Database and Table Info /  

$username="";  
$password="";  
$database="";  
$table="";  

mysql_connect(localhost,$username,$password);  
@mysql_select_db($database) or die( "Unable to select database");  
$select = "SELECT * FROM $table";                  
$export = mysql_query($select);  
$fields = mysql_num_fields($export);  

for ($i = 0; $i < $fields; $i++) {  
    $header .= mysql_field_name($export, $i) . ",";  
}  

while($row = mysql_fetch_row($export)) {  
    $line = '';  
    foreach($row as $value) {                                              
        if ((!isset($value)) OR ($value == "")) {  
            $value = ",";  
        } else {  
            $value = str_replace('"', '""', $value);  
            $value = '"' . $value . '"' . ",";  
        }  
        $line .= $value;  
    }  
    $data .= trim($line)."n";  
}  
$data = str_replace("r","",$data);  

if ($data == "") {  
    $data = "n(0) Records Found!n";                          
}  

header("Content-type: application/x-msdownload");  
header("Content-Disposition: attachment; filename=mailinglist.xls");  
header("Pragma: no-cache");  
header("Expires: 0");  
print "$headern$data";   
?> 
于 2010-09-15T14:21:29.717 に答える