Fastadmin Excel 导入实现

本文为整理项目开发中使用Fastadmin Excel实现导入功能的笔记

目录

实现导入

文件类型设置

增加导入按钮

增加导入方法

总结


实现导入

导出功能不用做,默认就可以导出;但导入就需要加载配置和结合业务进行处理。

文件类型设置

在application/extra/upload.php中设置可上传文件类型,

增加csv/xls/xlsx类型,如下:

php 复制代码
/**
 * 可上传的文件类型
 * 如配置允许 pdf,ppt,docx,svg 等可能含有脚本的文件时,
 * 请先从服务器配置此类文件直接下载而不是预览
 */
'mimetype'  => 'jpg,png,bmp,jpeg,gif,webp,zip,rar,wav,mp4,mp3,webm,csv,xls,xlsx',

增加导入按钮

在列表(index.html)文件中增加导入按钮,如下:

php 复制代码
{:build_toolbar('import')}

位置如下图:

效果如下图:

增加导入方法

在控制器中增加导入方法,获取导入文件,读取文件中的数据,并处理导入到数据表中。

如下:

php 复制代码
/**
 * 导入
 *
 * @return void
 * @throws PDOException
 * @throws BindParamException
 */
public function import()
{
    $file = $this->request->request('file');
    if (!$file) {
        $this->error(__('Parameter %s can not be empty', 'file'));
    }
    $filePath = ROOT_PATH . DS . 'public' . DS . $file;
    if (!is_file($filePath)) {
        $this->error(__('No results were found'));
    }

    // 实例化reader
    $ext = pathinfo($filePath, PATHINFO_EXTENSION);
    if (!in_array($ext, ['csv', 'xls', 'xlsx'])) {
        $this->error(__('Unknown data format'));
    }

    try {
        // 加载文件
        if (!$spreadsheet = IOFactory::load($filePath)) {
            $this->error(__('Unknown data format'));
        }
        $sheet = $spreadsheet->getActiveSheet();
        $data = [];
        foreach ($sheet->getRowIterator() as $row) {
            $rowIndex = $row->getRowIndex();
            // 不读取第一行 标题
            if ($rowIndex == 1) continue;

            $cellIterator = $row->getCellIterator();
            $row = [];
            foreach ($cellIterator as $cell) $row[] = $cell->getValue();
            $data[] = $row;
        }
    } catch (Exception $exception) {
        $this->error($exception->getMessage());
    }

    if (empty($data)) {
        $this->error('数据为空,无法导入');
    }

    // 在这里 验证数据格式 导入数据业务处理
    $this->success();
}

总结

在fastadmin中上传和导入已经集成,只需要实现导入数据的业务处理。

相关推荐
两个人的幸福10 天前
Windows 桌面应用自研 PHP 队列(下):完整代码与六大工程化优化
php
BingoGo12 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
JaguarJack12 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
用户30745969820713 天前
PHP 扩展——从入门到理解
php
鹏仔先生14 天前
拷贝漫画APP下载页PHP程序,后台带免费AI写作
php
Non-existent98714 天前
WPS批量清理单元格空白字符的4种方法-异常数字格式处理-实战
excel·wps
云水一下14 天前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php
xingpanvip14 天前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
酉鬼女又兒14 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php
dog25014 天前
不要再继续优化 TCP
网络协议·tcp/ip·php