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'],
        )
    );
}
相关推荐
是娇娇公主~3 小时前
C++ 中 std::deque 的原理?它内部是如何实现的?
开发语言·c++·stl
SuperEugene4 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
xuxie995 小时前
N11 ARM-irq
java·开发语言
wefly20175 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
luanma1509806 小时前
PHP vs C++:编程语言终极对决
开发语言·c++·php
寂静or沉默6 小时前
2026最新Java岗位从P5-P7的成长面试进阶资源分享!
java·开发语言·面试
kyriewen116 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
娇娇yyyyyy7 小时前
QT编程(18): Qt QItemSelectionModel介绍
开发语言·qt
豆豆的java之旅7 小时前
软考中级软件设计师 数据结构详细知识点(含真题+练习题,可直接复习)
java·开发语言·数据结构
sthnyph7 小时前
QT开发:事件循环与处理机制的概念和流程概括性总结
开发语言·qt