>백엔드 개발 >PHP 튜토리얼 >기사에서는 기본적으로 PHP를 사용하여 Excel 및 CSV 파일을 내보내는 방법을 설명합니다.

기사에서는 기본적으로 PHP를 사용하여 Excel 및 CSV 파일을 내보내는 방법을 설명합니다.

藏色散人
藏色散人앞으로
2021-07-23 14:11:474814검색

내보낸 의사 코드는 다음과 같습니다.
/**
 * 导出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 .= &#39;<tr style="height:25px;font-size:13px;font-weight: bold;">&#39;;
    foreach ($title as $key => $val) {
        $str .= &#39;<td>&#39;.$val.&#39;</td>&#39;;
    }
    $str .= &#39;</tr>&#39;;
    // 拼接数据
    foreach ($data as $key => $val) {
        $str .= &#39;<tr style="text-align: left;height:25px;font-size:13px;">&#39;;
        foreach ($val as $v) {
            if (is_numeric($v) && $v > 100000000) {
                $str .= "<td style=&#39;vnd.ms-excel.numberformat:@&#39;>".$v."</td>";
            } elseif (is_numeric($v) && preg_match(&#39;/^[0-9]+(\.[0-9]{2})+$/&#39;, $v)) {
                // 是两位小数的保留2位显示
                $str .= "<td style=&#39;vnd.ms-excel.numberformat:0.00&#39;>".$v."</td>";
            } elseif (preg_match(&#39;/^[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])$/&#39;, $v)) {
                // 是日期
                $str .= "<td style=&#39;vnd.ms-excel.numberformat:yyyy-mm-dd\ hh\:mm\:ss&#39;>".$v."</td>";
            } else {
                $str .= "<td>".$v."</td>";
            }
        }
        $str .= "</tr>\n";
    }
    $str .= "</table></body></html>";
    // 实现文件下载
    header("Content-Type: application/vnd.ms-excel; name=&#39;excel&#39;");
    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);
}
저는 단순히 몇 가지 스타일과 몇 가지 정기 검사를 작성했는데 필요하지 않으면 삭제할 수 있습니다. 주로 일부 셀의 서식 지정 지침에 대해 이야기합니다.

위 내보내기에는 몇 가지 일반적인 문제가 있습니다. td 的样式来控制单元格。

导出伪代码如下:

/**
 * 导出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(&#39;php://output&#39;, &#39;w&#39;);
    //转码 防止乱码
    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();
}

其中我简单写了些样式和一些正则校验,不用可以删除。主要说一下一些单元格的格式化说明。

以上的导出会有几个常见的问题:

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-formatvnd.ms-excel.numberformat

1. ID 번호, 휴대폰 번호 및 기타 지나치게 큰 숫자의 경우 과학적 표기법으로 표시됩니다. 문자열 표시에 신경쓰지 않는다면 td style='vnd.ms-excel.numberformat:@' 스타일을 설정하여 제어할 수 있습니다.

2 숫자의 경우 소수점 이하 자릿수를 유지해야 하는 경우 필요한 경우 style='vnd.ms-excel.numberformat:0.00'을 설정할 수 있습니다. 소수점 이하 자릿수를 몇 개만 입력하면 됩니다. 통과할 경우 입력한 값이 유지되는 소수점 이하 자릿수를 초과하면 값이 반올림됩니다. 예를 들어 입력값이 87.98이고 소수점 이하 자릿수 설정이 vnd.ms-excel.numberformat:0.0이면 88.0

3으로 표시됩니다. 날짜 형식은 로 설정하세요. >style='vnd.ms-excel.numberformat:yyyy-mm-dd hh:mm:ss' 공백, 콜론 등은 이스케이프되어야 합니다. HTML에서 공백 문자표를 사용하는 경우에는 조금 다릅니다. 위의 내용은 일반적으로 사용되는 형식 조합이므로 직접 변환할 수 있습니다. 2019/7/1로 표시되는 몇 가지 다른 변환 style='vnd.ms-excel.numberformat:"Short Date"'이 있습니다. ='vnd.ms-excel.numberformat:"중간 날짜"'는 1-Jul-19

4로 표시됩니다. 백분율을 표시하려면 style='vnd.ms-excel.numberformat:0%' 형식을 사용할 수 있습니다. 주의할 점은 표시할 때 값이 100배 증폭된다는 것입니다. 즉, 2%로 표시하려면 전달하는 값이 0.02

5여야 합니다. 천 단위 구분 기호를 사용하여 숫자를 표시해야 하는 경우 style='vnd.ms-excel.numberformat:#,###'를 설정하면 됩니다. 예를 들어 123456123,456로 표시됩니다

위는 가장 일반적으로 사용되는 목록입니다. 여기에도 일반적으로 사용되는 목록이 있지만 그가 사용한 키워드는 mso-number-format입니다. style을 사용해 보았습니다. mso-number-formatvnd.ms-excel.numberformat을 모두 code>에서 사용할 수 있습니다.

PHP는 CSV를 내보냅니다🎜🎜CSV 파일은 실제로 범용 파일이며 때로는 텍스트 파일이라고도 합니다. 따라서 내보낸 CSV 데이터그램 파일은 셀 스타일을 설정할 수 없으며, xls 파일은 바이너리 파일이므로 엑셀 등의 도구를 이용하여 열어야 합니다. 이것을 더 빨리 내보내야 한다는 엄격한 요구 사항이 없다면 Alibaba Cloud의 일부 내보내기는 CSV 형식인 것을 알 수 있지만 여기서 필요한 것은 Excel 파일이어야 합니다. 🎜🎜의사 코드는 다음과 같습니다. 🎜rrreee🎜🎜추천 연구: "🎜 PHP 동영상 튜토리얼 🎜》                                                                                                                                                                  ''s ' to 🎜               ''s to ’ ‐ to ‐ ‐ ‐ ‐ ‐ ,

위 내용은 기사에서는 기본적으로 PHP를 사용하여 Excel 및 CSV 파일을 내보내는 방법을 설명합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제