日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

PHP原生導出Excel

導出的原理其實就是通過設置Header頭告訴瀏覽器用excel的格式來解析讀取,然后通過生成HTML表格來輸出內容。對于單元格的合并其實就和操作HTML表格的合并是一樣的了,支持樣式的屬性和字段,同時還可以操作 td 的樣式來控制單元格。

導出偽代碼如下:

/**
 * 導出excel文件
 *
 * @param string $excelFileName 導出的文件名
 * @param array $title excel的標題列
 * @param array $data 導出的數據
 */
public function exportExcel($excelFileName, $title, $data)
{
    $str = "<html xmlns:o=\"urn:schemas-microsoft-com:office:office\"\r\nxmlns:x=\"urn:schemas-microsoft-com:office:excel\"\r\nxmlns=\"http://www.w3.org/TR/REC-html40\">\r\n<head>\r\n<meta http-equiv=Content-Type content=\"text/html; charset=utf-8\">\r\n</head>\r\n<body>";
    $str .="<table border=1 align=center cellpadding=0 cellspacing=0>";
    // 拼接標題行
    $str .= '<tr style="height:25px;font-size:13px;font-weight: bold;">';
    foreach ($title as $key => $val) {
        $str .= '<td>'.$val.'</td>';
    }
    $str .= '</tr>';
    // 拼接數據
    foreach ($data as $key => $val) {
        $str .= '<tr style="text-align: left;height:25px;font-size:13px;">';
        foreach ($val as $v) {
            if (is_numeric($v) && $v > 100000000) {
                $str .= "<td style='vnd.ms-excel.numberformat:@'>".$v."</td>";
            } elseif (is_numeric($v) && preg_match('/^[0-9]+(\.[0-9]{2})+$/', $v)) {
                // 是兩位小數的保留2位顯示
                $str .= "<td style='vnd.ms-excel.numberformat:0.00'>".$v."</td>";
            } elseif (preg_match('/^[0-9]{4}-(0[1-9]|1[0-2])-(0[1-9]|[1-2][0-9]|3[0-1]) (0[0-9]|1[0-9]|2[0-4]):(0[0-9]|[1-5][0-9]):(0[0-9]|[1-5][0-9])$/', $v)) {
                // 是日期
                $str .= "<td style='vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss'>".$v."</td>";
            } else {
                $str .= "<td>".$v."</td>";
            }
        }
        $str .= "</tr>\n";
    }
    $str .= "</table></body></html>";
    // 實現文件下載
    header("Content-Type: application/vnd.ms-excel; name='excel'");
    header("Content-type: application/octet-stream");
    header("Content-Disposition: attachment; filename=" . $excelFileName);
    header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
    header("Pragma: no-cache");
    header("Expires: 0");
    exit($str);
}

其中我簡單寫了些樣式和一些正則校驗,不用可以刪除。主要說一下一些單元格的格式化說明。


以上的導出會有幾個常見的問題:

1、對于身份證號,手機號等過大的數字 顯示的時候會用科學計數法顯示。如果不介意字符串顯示的話可以通過設置 td 的樣式來控制 style='vnd.ms-excel.numberformat:@' 這樣表示用文本的方式來顯示

2、對于數字如果需要保留小數位可以設置 style='vnd.ms-excel.numberformat:0.00' 需要保留幾位小數就寫幾個0,需要注意一點如果你傳入的值比保留的小數位多,那么值會被四舍五入。比如傳入的是 87.98 而設置的保留小數位是 vnd.ms-excel.numberformat:0.0 那么會顯示成 88.0

3、對于日期格式設置 style='vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss' 其中空格、冒號等都需要轉義。如果使用的是HTML里的空格字符表輔助出來會有些不一樣,上面是常用的格式組合,可以自己做轉換。還有一些別的轉換 style='vnd.ms-excel.numberformat:\"Short Date\"' 這個會顯示成 2019/7/1; style='vnd.ms-excel.numberformat:\"Medium Date\"' 會顯示成 1-Jul-19

4、百分比顯示。 要顯示百分比的話 可以使用格式 style='vnd.ms-excel.numberformat:0%' 有一點需要注意顯示的時候會把你的值放大100倍。也就是說假如你想顯示成 2% 你傳遞進來的值需要是 0.02

5、千位分隔符。如果需要數字顯示帶千位分隔符可以設置 style='vnd.ms-excel.numberformat:#,###' 比如 123456 就會顯示成 123,456

常用的也就上面這些了 這里還有個 常用列表 不過他使用的關鍵字是 mso-number-format 我嘗試了下 style 中使用 mso-number-format 和 vnd.ms-excel.numberformat 都可以。


PHP導出CSV

CSV文件其實是一種通用的文件,有時也被叫做文本文件。因此導出的CSV數據報文件不能設置單元格的樣式,而xls屬于二進制的文件需要使用Excel之類的工具才能打開。如果沒有硬性要求導出這種速度更快,我看阿里云上的一些導出都是CSV格式,但是我們這邊的需要非要excel文件。

代碼如下:

/**
 * 導出CSV標準文件
 *
 * @param string $fileName 導出的文件名
 * @param array $title 標題列
 * @param array $data 導出的數據
 */
function exportCsv($fileName, $title, $data)
{
    // 清空輸出流,防止有別的信息
    ob_end_clean();
    // 打開一個輸出流
    ob_start();
    // 設置header信息
    header("Content-Type: text/csv");
    header("Content-Disposition:filename=". $fileName);
    // 打開文件流
    $fileHandle = fopen('php://output', 'w');
    //轉碼 防止亂碼
    fwrite($fileHandle, chr(0xEF).chr(0xBB).chr(0xBF));
    // 先把標題寫進去
    fputcsv($fileHandle, $title);
    $index = 0;
    foreach ($data as $item) {
        // 每2000條釋放一次資源
        if ($index == 2000) {
            $index = 0;
            ob_flush();
            flush();
        }
        $index++;
        fputcsv($fileHandle, $item);
    }
    // 釋放資源
    ob_flush();
    flush();
    ob_end_clean();
}


分享到:
標簽:PHP原生導出Excel PHP導出CSV
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定