laravel 導出插件

轉發:https://blog.csdn.net/gu_wen_jie/article/details/79296470

版本:laravel5

? ? ? ? ? php 5.6

安裝步驟:

一、安裝插件

①、首先在Laravel項目根目錄下使用Composer安裝依賴:

composer require "maatwebsite/excel:~2.1.0"

②、在config/app.php中注冊服務提供者到providers數組:

Maatwebsite\Excel\ExcelServiceProvider::class,

?

③、在config/app.php中注冊門面到aliases數組:

'Excel' => Maatwebsite\Excel\Facades\Excel::class,

④、建議你生成Laravel Excel的配置文件,使用如下命令:

php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider"

?

然后你會發現在config目錄下有一個excel.php文件?
你可以打開看一下大概的配置項,主要就是緩存,表單,和導入,導出的一些設置。

?

二、使用

①、創建路由:

//Excel導出 Route::get('/excel/export','Member\MemberController@export')->name('/excel/export');

//Excel導入 Route::get('/excel/import','Member\MemberController@import')->name('/excel/import');?

1-1、導出的方法:

<?phpnamespace App\Http\Controllers\Member;use App\Http\Controllers\BaseController;
use App\Model\Member\MemberFollow;
use Illuminate\Http\Request;
use Illuminate\Database\QueryException;
use Excel;class MemberController extends BaseController
{/**** Excel導出*/public function export(){ini_set('memory_limit','500M');set_time_limit(0);//設置超時限制為0分鐘$cellData = MemberFollow::select('xt_name','sex','face')->limit(5)->get()->toArray();$cellData[0] = array('昵稱','性別','頭像');for($i=0;$i<count($cellData);$i++){$cellData[$i] = array_values($cellData[$i]);$cellData[$i][0] = str_replace('=',' '.'=',$cellData[$i][0]);}//dd($cellData);Excel::create('用戶信息',function($excel) use ($cellData){$excel->sheet('score', function($sheet) use ($cellData){$sheet->rows($cellData);});})->export('xls');die;}
}

我來對上面的代碼進行解釋下。
a. ini_set設置內存溢出大小和超時時間是因為我的數據量比較大,不想直接去php.ini中修改,所以直接在這設置。你也可以修改excel.php配置項中的緩存大小,適當調整。
b. 首先你得需要知道cellData是一個二維數組,并且二維數組中的每一個一維數組必須是索引數組才行,這樣格式上才能正確。
所以,我對我查詢出的$cellData先進行了toArray()轉化操作。然后我讓你看下查詢出的結構,因為我們數組表中的每個列都是一個字段,所以決定了一維數組是關聯數組,需要去鍵處理。

for循環處理后就是:

?

??for循環中的另一個
php
$cellData[$i][0] = str_replace('=',' '.'=',$cellData[$i][0]);

這個地方是比較坑的一個地,因為Excel單元格當你的導出數據中某個列的某個值第一個字符是等號“=”,他就會進行計算處理,然后就報錯了。比如我到處的某個昵稱是“=陽光”,我就吧等號匹配替換為空格加等號了
其實本不需要進行匹配替換的,因為在excel.php文件中有配置項,但是我配置了并不生效,后續找到更好的解決方法會及時更新,或者有哪位知道了可以指點一下。 ?

 /*|--------------------------------------------------------------------------| Calculate|--------------------------------------------------------------------------|| By default cells with formulas will be calculated.|*/'calculate'               => false,---------------------
作者:谷谷谷 
來源:CSDN 
原文:https://blog.csdn.net/gu_wen_jie/article/details/79296470?utm_source=copy 
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!

  

默認情況下,計算公式的單元格將被計算。我設置為false沒生效。所以匹配替換。

如果你要導出csv或者xlsx文件,只需將export方法中的參數改成csv或xlsx即可。也可以進行連貫操作直接將導出的文件直接保存到服務器上。?
使用store方法:

 Excel::create('用戶信息',function($excel) use ($cellData){$excel->sheet('score', function($sheet) use ($cellData){$sheet->rows($cellData);});})->store('xls')->export('xls');---------------------
作者:谷谷谷 
來源:CSDN 
原文:https://blog.csdn.net/gu_wen_jie/article/details/79296470?utm_source=copy 
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!

  ok,導出完成。

?

2-1 導入:

導入我們可以直接用第一步注冊的門面Excel門面上的load方法

/**** Excel導入*/public function import(){$filePath = 'storage/exports/'.iconv('UTF-8', 'GBK', '用戶信息').'.xls';Excel::load($filePath, function($reader) {$data = $reader->all();dd($data);});}

  ok,導入完成。

?

轉載于:https://www.cnblogs.com/sz-xioabai/p/9765382.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/389542.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/389542.shtml
英文地址,請注明出處:http://en.pswp.cn/news/389542.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

國外 廣告牌_廣告牌下一首流行歌曲的分析和預測,第1部分

國外 廣告牌Using Spotify and Billboard’s data to understand what makes a song a hit.使用Spotify和Billboard的數據來了解歌曲的流行。 Thousands of songs are released every year around the world. Some are very successful in the music industry; others less so…

Jmeter測試普通java類說明

概述 Apache JMeter是Apache組織開發的基于Java的壓力測試工具。本文檔主要描述用Jmeter工具對基于Dubbo、Zookeeper框架的Cassandra接口、區塊鏈接口進行壓力測試的一些說明&#xff0c;為以后類似接口的測試提供參考。 環境部署 1、 下載Jmeter工具apache-jmeter-3.3.zip&am…

opencv:Canny邊緣檢測算法思想及實現

Canny邊緣檢測算法背景 求邊緣幅度的算法&#xff1a; 一階導數&#xff1a;sobel、Roberts、prewitt等算子 二階導數&#xff1a;Laplacian、Canny算子 Canny算子效果比其他的都要好&#xff0c;但是實現起來有點麻煩 Canny邊緣檢測算法的優勢&#xff1a; Canny是目前最優…

關于outlook簽名圖片大小的說明

96 dpiwidth576 height114轉載于:https://blog.51cto.com/lch54734/2298115

opencv:畸變矯正:透視變換算法的思想與實現

畸變矯正 注意&#xff1a;雖然能夠成功矯正但是也會損失了部分圖像&#xff01; 透視變換(Perspective Transformation) 概念&#xff1a; 透視變換是將圖片投影到一個新的視平面(Viewing Plane)&#xff0c;也稱作投影映射(Projective Mapping)。 我們常說的仿射變換是透視…

數據多重共線性_多重共線性對您的數據科學項目的影響比您所知道的要多

數據多重共線性Multicollinearity is likely far down on a mental list of things to check for, if it is on a list at all. This does, however, appear almost always in real-life datasets, and it’s important to be aware of how to address it.多重共線性可能根本不…

PHP工廠模式計算面積與周長

<?phpinterface InterfaceShape{ function getArea(); function getCircumference();}/** * 矩形 */class Rectangle implements InterfaceShape{ private $width; private $height; public function __construct($width,$height){ $this->width$…

K-Means聚類算法思想及實現

K-Means聚類概念&#xff1a; K-Means聚類是最常用的聚類算法&#xff0c;最初起源于信號處理&#xff0c;其目標是將數據點劃分為K個類簇&#xff0c; 找到每個簇的中心并使其度量最小化。 該算法的最大優點是簡單、便于理解&#xff0c;運算速度較快&#xff0c;缺點是只能應…

(2.1)DDL增強功能-數據類型、同義詞、分區表

1.數據類型 &#xff08;1&#xff09;常用數據類型  1.整數類型 int 存儲范圍是-2,147,483,648到2,147,483,647之間的整數&#xff0c;主鍵列常設置此類型。 &#xff08;每個數值占用 4字節&#xff09; smallint 存儲范圍是-32,768 到 32,767 之間的整數&#xff0c;用…

充分利用昂貴的分析

By Noor Malik努爾馬利克(Noor Malik) Let’s say you write a query in Deephaven which performs a lengthy and expensive analysis, resulting in a live table. For example, in a previous project, I wrote a query which pulled data from an RSS feed to create a li…

【java并發編程藝術學習】(一)初衷、感想與筆記目錄

不忘初心&#xff0c;方得始終。 學習java編程這么長時間&#xff0c;自認為在項目功能需求開發中沒啥問題&#xff0c;但是之前的幾次面試和跟一些勤奮的或者小牛、大牛級別的人的接觸中&#xff0c;才發現自己的無知與淺薄。 學習總得有個方向吧&#xff0c;現階段就想把并發…

層次聚類和密度聚類思想及實現

層次聚類 層次聚類的概念&#xff1a; 層次聚類是一種很直觀的算法。顧名思義就是要一層一層地進行聚類。 層次法&#xff08;Hierarchicalmethods&#xff09;先計算樣本之間的距離。每次將距離最近的點合并到同一個類。然后&#xff0c;再 計算類與類之間的距離&#xff0…

通配符 或 怎么濃_濃咖啡的咖啡渣新鮮度

通配符 或 怎么濃How long could you wait to brew espresso after grinding? Ask a barista, any barista, and I suspect their answer is immediately or within a few minutes. The common knowledge on coffee grounds freshness is that after 30 minutes or so, coffee…

保留

看見 你在我眼前 不去猜想我們隔多遠 當我 夜幕中準備 只想讓沉默的能開解 在不同的遭遇里 我發現你的瞬間 有種不可言說的溫柔直覺 在有限的深夜消失之前 觸摸你的臉 我情愿這是幻覺 也不愿是種告別 已經忘了 你的名字 就在這座 寂靜星石 怎么還有 你的樣子 被保留 給我 一整個…

《netty入門與實戰》筆記-02:服務端啟動流程

為什么80%的碼農都做不了架構師&#xff1f;>>> 1.服務端啟動流程 這一小節&#xff0c;我們來學習一下如何使用 Netty 來啟動一個服務端應用程序&#xff0c;以下是服務端啟動的一個非常精簡的 Demo: NettyServer.java public class NettyServer {public static v…

譜聚類思想及實現

&#xff08;這個我也沒有怎么懂&#xff0c;為了防止以后能用上&#xff0c;還是記錄下來&#xff09; 譜聚類 注意&#xff1a;譜聚類核心聚類算法還是K-means 算法進行聚類~ 譜聚類的實現過程&#xff1a; 1.根據數據構造一個 圖結構&#xff08;Graph&#xff09; &…

Tengine HTTPS原理解析、實踐與調試【轉】

本文邀請阿里云CDN HTTPS技術專家金九&#xff0c;分享Tengine的一些HTTPS實踐經驗。內容主要有四個方面&#xff1a;HTTPS趨勢、HTTPS基礎、HTTPS實踐、HTTPS調試。 一、HTTPS趨勢 這一章節主要介紹近幾年和未來HTTPS的趨勢&#xff0c;包括兩大瀏覽器chrome和firefox對HTTPS的…

Linux 指定運行時動態庫路徑【轉】

轉自&#xff1a;http://www.cnblogs.com/cute/archive/2011/02/24/1963957.html 眾所周知&#xff0c; Linux 動態庫的默認搜索路徑是 /lib 和 /usr/lib 。動態庫被創建后&#xff0c;一般都復制到這兩個目錄中。當程序執行時需要某動態庫&#xff0c; 并且該動態庫還未加載到…

opencv:SIFT——尺度不變特征變換

SIFT概念&#xff1a; Sift&#xff08;尺度不變特征變換&#xff09;&#xff0c;全稱是Scale Invariant Feature Transform Sift提取圖像的局部特征&#xff0c;在尺度空間尋找極值點&#xff0c;并提取出其位置、尺度、方向信息。 Sfit的應用范圍包括 物體辨別、機器人地圖…

pca(主成分分析技術)_主成分分析技巧

pca(主成分分析技術)介紹 (Introduction) Principal Component Analysis (PCA) is an unsupervised technique for dimensionality reduction.主成分分析(PCA)是一種無監督的降維技術。 What is dimensionality reduction?什么是降維&#xff1f; Let us start with an exam…