php之导入导出csv文件

一、导入csv文件

1、创建导入页面

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<meta charset="UTF-8">
<head>
    <title>文件提交表单</title>
</head>
<body>
<form action="test5.php" method="post" enctype="multipart/form-data">
    <label for="file">选择文件:</label>
    <input type="file" name="file" id="file">
    <input type="submit" name="submit" value="导入">
</form>
</body>
</html>

2、导入后端处理test5.php

php 复制代码
<?php
/**
 * $filename 文件
 * $lineOne 是否显示标题
*/
function parseFile($filename,$lineOne=false) {
    if (!$filename) {
        die("未选择文件");
    }
    $file = fopen($filename, 'r');
    $arr = [];
    $i=0;
    while ($line = fgets($file)) {
        $i++;
        if($i==1&&!$lineOne){
           continue;
        }
        $line = rtrim($line, "\n\r\0");
        $encoding = mb_detect_encoding($line, ['utf-8', 'gbk', 'latin1', 'big5']);
        if ($encoding != 'utf-8') {
            $line = mb_convert_encoding($line, 'utf-8', $encoding);
        }

        $arr[] = explode(',', $line);

    }
    return $arr;
}
$filename = $_FILES['file']['tmp_name'];
$result = parseFile($filename);
print_r($result);

二、导出csv文件

php 复制代码
<?php
 
$output = fopen('php://output', 'w');
header('Content-type: application/csv;');
header('Content-Disposition: attachment; filename="测试------' . date("YmdHis", time()) . ".csv");
 
fputcsv($output, [
        iconv('UTF-8', 'GB2312', "标题"),
        iconv('UTF-8', 'GB2312', '哈哈'),
    ]
);
 
 
fputcsv($output, [
 
 
        iconv('UTF-8', 'GB2312', "名称"),
        iconv('UTF-8', 'GB2312', "年龄"),
        iconv('UTF-8', 'GB2312', "生日"),
    ]
 
);
$data=[
    ["name"=>'小明','age'=>'22','date'=>'1994-01-12'],
    ["name"=>'小a','age'=>'12','date'=>'1994-01-33'],
    ["name"=>'小b','age'=>'33','date'=>'1994-01-22'],
    ["name"=>'小c','age'=>'21','date'=>'1994-01-22'],
    ["name"=>'小d','age'=>'11','date'=>'1994-01-12'],
    ["name"=>'小e','age'=>'22','date'=>'1994-01-12'],
    ["name"=>'小e','age'=>'33','date'=>'1994-01-01'],
];
 
foreach ($data as $value){
 
 
    fputcsv($output, array(
            iconv('UTF-8', 'GB2312', $value['name']),
            "\t" . $value['age'],
            "\t" . $value['date'],
        )
    );
}
相关推荐
BingoGo1 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php
JaguarJack1 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php·服务端
BingoGo2 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php
JaguarJack2 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php·服务端
JaguarJack3 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
后端·php·服务端
BingoGo3 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
php
JaguarJack4 天前
告别 Laravel 缓慢的 Blade!Livewire Blaze 来了,为你的 Laravel 性能提速
后端·php·laravel
郑州光合科技余经理5 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
feifeigo1235 天前
matlab画图工具
开发语言·matlab
dustcell.5 天前
haproxy七层代理
java·开发语言·前端