Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk menyelesaikan masalah kacau php fputcsv

Bagaimana untuk menyelesaikan masalah kacau php fputcsv

藏色散人
藏色散人asal
2021-09-12 14:07:592604semak imbas

Penyelesaian kepada php fputcsv yang bercelaru: 1. Letakkan fungsi pengepala sebelum fopen; 2. Output terus ke pelayar melalui "fopen('php://output', 'a');" cuma tambah bom pada permulaan rentetan pertama yang ditulis.

Bagaimana untuk menyelesaikan masalah kacau php fputcsv

Persekitaran pengendalian artikel ini: sistem Windows 7, PHP versi 7.1, komputer DELL G3

Cara untuk selesaikan kod kacau php fputcsv Masalah?

PHP menggunakan fputcsv() untuk menjana fail csv dan membukanya di bawah windows Excel untuk menyelesaikan masalah aksara bercelaru

Fail csv dibuka seperti biasa di bawah windows wps dan versi desktop ubuntu16 saya.

Tetapi menggunakan windows Excel membuka aksara yang bercelaru.

Penyelesaian:

    function test() {
        $fileName = 'demo';
        // 几个header函数需要放fopen之前。不然会直接在浏览器页面打印输出。而不是文件下载
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="'.$fileName.'.csv"');
        header('Cache-Control: max-age=0');
        //直接输出到浏览器
        $fp = fopen('php://output', 'a');
        //在写入的第一个字符串开头加 bom。
        $bom =  chr(0xEF).chr(0xBB).chr(0xBF);
        $column = [
            $bom.'姓名','性别', '年龄'
        ];
        $data = [
            '张三','男士', '21'
        ];
        fputcsv($fp, $column);
        fputcsv($fp, $data);
        fclose($fp);}

Pembelajaran yang disyorkan: "Tutorial Video PHP"

Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah kacau php fputcsv. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn