<?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. git命令移动文件夹到另一文件夹

  2. input只能输入数字和小数点,并且只能保留小数点后两位 - CSDN博客

    1.给文本框添加一个onkeyup=’clearNoNum(this)’点击事件 2.建立clearNoNum方法 function clearNoNum(obj) { obj.value = obj ...

  3. Vue2.0史上最全入坑教程(中)—— 脚手架代码详解

    书接上文我们说道,如何利用脚手架(vue-cli)构建一个vue项目,本回书我们一起来学习分析下代码. 回顾下创建后的项目目录:   说明:在*.vue文件,template标签里写html代码,且t ...

  4. excel一些常用的函数

    函数分类: 关联匹配类 清洗处理类 逻辑运算类 计算统计类 时间序列类 一.关联匹配类 经常性的,需要的数据不在同一个excel表或同一个excel表不同sheet中,数据太多,copy麻烦也不准确, ...

  5. selenium(2):环境搭建完成后,初步运行遇到的问题

    检验是否搭建成功. . 问题一:运行时候,报错:请停用以开发者模式运行的扩展程序 出现错误如下: 原因:chromedriver的版本号过低了. 解决办法:应该安装与chrome版本对应的chrome ...

  6. HDU 2639 第K大背包问题

    //状态方程和01背包类似,dp[j][k]表示背包容量为j的第k大背包的值.......... //应当注意的是此时dp[j][1.....k]应当是递减的.................... ...

  7. 洛谷 P3950 部落冲突 树链剖分

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例1 输出样例1 输入样例2 输出样例2 输入样例3 输出样例3 说明 思路 AC代码 总结 题面 题目链接 P3 ...

  8. JDBC的事务处理 JDBC事务处理 JDBC教程

    JDBC的事务基本知识 事务的定义:一个事务是由一条或多条对数据库操作的sql语句所组成的一个不可分割的工作单元,只有当事务中的所有操作都正常执行后,整个事务才会提交给数据库. 结束事务的操作:com ...

  9. 跨境网上收款 找PayPal没错(php如何实现paypal支付)

    开发前准备 在我的博客中 有介绍如何获取ID 和 secret : 好了 在上一篇博客中详细介绍了也不少: 跨境网上收款 找PayPal没错(如何获取ID 和 secret) http://blog. ...

  10. px和rem换算

    bootstrap默认 html{font-size: 10px;} rem是一个相对大小的值,它相对于根元素<html>, 假设,我们设置html的字体大小的值为html{font-si ...