<?php

namespace App\Admin\Controllers;

use App\AdminUser;
use Illuminate\Http\Request; use Excel;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint; class ExcelController extends Controller
{
//
public function index()
{
return view('admin/excel/index');
} //导出
public function export(Request $request)
{
/* $cellData = array(['学号', '姓名', '成绩'], ['10001', 'AAAAA', '99']);
Excel::create('学生成绩', function ($excel) use ($cellData) {
$excel->sheet('score', function ($sheet) use ($cellData) {
$sheet->rows($cellData);
});
})->export('xls');*/ //方法二:
$users = AdminUser::all()->toArray();
$header[] = array('ID号', '姓名', '邮箱', '创建时间', '状态');
$arr = array();
foreach ($users as $one) {
$data = array($one['id'], $one['name'], $one['email'], $one['created_at'], $one['status']);
array_push($arr, $data);
}
$arrData = array_merge($header, $arr); Excel::create(iconv('UTF-8', 'UTF-8', '管理员表'), function ($excel) use ($arrData) {
$excel->sheet('score', function ($sheet) use ($arrData) {
$sheet->rows($arrData);
});
})->store('xlsx')->export('xlsx');
} //导入
public function import(Request $request)
{
/*$filePath = 'storage/exports/' . iconv('UTF-8', 'GBK', '学生成绩') . '.xls';
Excel::load($filePath, function ($reader) {
$data = $reader->all();
dd($data);
});*/ // $file=Input::file('file'); dd(base_path());
$file = $request->file('file');
$tabl_name = date('YmdHis', time()) . rand(100, 999);
$entension = $file->getClientOriginalExtension(); //上传文件的后缀.
$new_name = $tabl_name . '.' . $entension;
if ($file->isValid()) {
$path = $request->file('file')->storeAs('import', $new_name);
// 更新文件本地地址 storage/import/20180720105908.xlsx
$path = '/public/storage/' . $path;
// dd($path); ///public/storage/import/20180720124843.xlsx"
Excel::load($path, function ($reader) use ($tabl_name) {
//$data = $reader->all();
//获取Excel的第几张表
$reader = $reader->getSheet(0);
//获取表中数据
$data = $reader->toArray();
// dd($data);
$result = $this->create_table($tabl_name, $data);
// dd($result);
});
} return redirect('/admin/files');
} //创建表
public function create_table($table_name, $field_arr)
{
$tmp = $table_name;
$val = $field_arr;
//创建表结构 因为已经有db_import表不再需要执行创建表结构程序。
//注意Excel标题最好是英文
/* $tables = DB::select("show tables");
$tables = array_column($tables, 'Tables_in_blog');*/
$tables = array_map('reset', \DB::select('SHOW TABLES'));
if (!in_array('db_import', $tables)) {
Schema::dropIfExists('db_import');
Schema::create("db_import", function (Blueprint $table) use ($tmp, $val) {
$fields = $val[0]; //列字段
$table->increments('id'); //主键
foreach ($fields as $key => $value) {
$table->string($fields[$key]);
}
});
} //填充数据
$value_str = array();
if ($id = DB::table('db_import')->max('id')) {
$id = $id + 1;
} else {
$id = 1;
}
//$id = DB::table('db_import')->max('id') ? DB::table('db_import')->max('id') + 1 : 1;
foreach ($val as $key => $value) {
if ($key != 0) {
// $content = implode(',', $value);
// $content2 = explode(',', $content);
foreach ($value as $key2 => $va2) {
if (!empty($va2)) {
$value_str[] = "'$va2'";
}
}
$news = implode(',', $value_str);
if (!empty($news)) {
$news = "$id," . $news;
DB::insert("insert into db_import VALUES ($news)");
} $value_str = array();
$id = $id + 1;
}
}
return $id;
} }

larave5.6 将Excel文件数据导入数据库代码实例的更多相关文章

  1. springMVC(5)---导入excel文件数据到数据库

    springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...

  2. 将Excel中数据导入数据库(一)

    在工作中经常要将Excel中数据导入数据库,这里介绍一种方法. 假如Excel中的数据如下: 数据库建表如下: 其中Id为自增字段: Excel中数据导入数据库帮助类如下: using System; ...

  3. 将Excel中数据导入数据库(三)

    上篇文章将Excel中数据导入数据库时,将从Excel读入的数据均转换成了数据库相应字段的类型,其实这是没有必要的,因为对于数据库各种类型的插入,均可以字符串格式插入.比如表WQ_SWMSAR_A字段 ...

  4. 将Excel中数据导入数据库(二)

    在上篇文章中介绍到将Excel中数据导入到数据库中,但上篇文章例子只出现了nvachar类型,且数据量很小.今天碰到将Excel中数据导入数据库中的Excel有6419行,其中每行均有48个字段,有i ...

  5. Excel表数据导入数据库表中

    ***Excel表数据导入到数据库表中 通过数据库表的模板做成‘Excel’表的数据导入到数据库相应的表中(注意:主表 和 从表的关系,要先导‘主表’在导入从表) 过程:通过数据库的导入工具—先导入为 ...

  6. 将Excel文件数据导入到SqlServer数据库的三种方案

    方案一: 通过OleDB方式获取Excel文件的数据,然后通过DataSet中转到SQL Server,这种方法的优点是非常的灵活,可以对Excel表中的各个单元格进行用户所需的操作. openFil ...

  7. java读取excel文件数据导入mysql数据库

    这是我来公司的第二周的一个小学习任务,下面是实现过程: 1.建立maven工程(方便管理jar包) 在pom.xml导入 jxl,mysql-connector 依赖 可以在maven仓库搜索 2.建 ...

  8. Excel文件数据导入到后台保存倒数据库

    后台代码数据解析: 方法一: (简单点) import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.usermo ...

  9. 将 excel文件数据导入MySQL数据库中

    第一步:先将Excel文件另存为文本文件(制表符分割) 第二步:将生成的txt文件另存,并修改编码格式utf8; 第三步:将文件放到指定位置,或自己想要的位置: G:\city.txt 第四步:避免创 ...

随机推荐

  1. 30分钟学webpack实战

    阅读目录 一:什么是webpack? 他有什么优点? 二:如何安装和配置 三:理解webpack加载器 四:理解less-loader加载器的使用 五:理解babel-loader加载器的含义 六:了 ...

  2. 2019阿里云开年Hi购季基础云产品分会场全攻略!

    2019阿里云云上Hi购季活动已经于2月25日正式开启,从已开放的活动页面来看,活动分为三个阶段: 2月25日-3月04日的活动报名阶段.3月04日-3月16日的新购满返+5折抢购阶段.3月16日-3 ...

  3. 记CRenderTarget:DrawText()绘制中文乱码的BUG及解决办法

    原文:记CRenderTarget:DrawText()绘制中文乱码的BUG及解决办法 转载请注明出处:http://www.cnblogs.com/Ray1024 一.问题描述 在MFC中使用Dir ...

  4. js流星雨效果

    css部分 div { border: 0px solid #fff; border-width: 0px 90px 2px 90px; border-color: transparent trans ...

  5. Python 匹配IP地址的正则表达式

  6. 洛谷P1063 能量项链 [2006NOIP提高组]

    P1063 能量项链 题目描述 在Mars星球上,每个Mars人都随身佩带着一串能量项链.在项链上有N颗能量珠.能量珠是一颗有头标记与尾标 记的珠子,这些标记对应着某个正整数.并且,对于相邻的两颗珠子 ...

  7. LintCode_167 链表求和

    题目 你有两个用链表代表的整数,其中每个节点包含一个数字.数字存储按照在原来整数中相反的顺序,使得第一个数字位于链表的开头.写出一个函数将两个整数相加,用链表形式返回和. 样例 给出两个链表 3-&g ...

  8. nodeJs学习-16 数据字典示例

    1.banner ID title 标题 varchar(32) sub_title 副标题 varchar(16) src 图片地址 varchar(64) 2.文章 ID author 作者 va ...

  9. react-cnode

    感谢无私开源的程序员们~~~代码因为你们更加美腻~ //根index.js import React, { Fragment } from 'react'; import ReactDOM from ...

  10. Servlet工作流程

    1.加载Servlet类 类加载器负责加载servlet类. 当Web容器接收到servlet的第一个请求时,将加载servlet类. 2.创建Servlet实例 Web容器在加载servlet类之后 ...