php Spreadsheet 導出,PhpSpreadsheet 導出Excel

/**

* Excel 助手

* sudo composer require phpoffice/phpspreadsheet

*/

namespace CommonUtil;

use PhpOfficePhpSpreadsheetSpreadsheet;

use PhpOfficePhpSpreadsheetWriterXlsx;

use PhpOfficePhpSpreadsheetStyleAlignment;

use PhpOfficePhpSpreadsheetStyleColor;

class ExcelUtil extends CommonUtil

{

public function __construct()

{

parent::__construct();

}

/**

* 導出數據

*/

public function exportExcel($expTitle, $expCellName, $expTableData)

{

$fileName = $expTitle;

$spreadsheet = new Spreadsheet();

// 獲取活動的工作空間

$worksheet = $spreadsheet->getActiveSheet();

$cellNum = count($expCellName);

$dataNum = count($expTableData);

$cellName = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');

// 合并單元格

$worksheet->mergeCells('A1:'.$cellName[$cellNum - 1] . '1');

// 設置第一格的內容

$worksheet->setCellValue('A1', $expTitle);

// 設置加粗

$worksheet->getStyle('A1')->getFont()->setBold(true);

// 設置居中

$styleArray = [

'alignment' => [

'horizontal' => Alignment::HORIZONTAL_CENTER,

],

];

$worksheet->getStyle('A1')->applyFromArray($styleArray);

// 設置顏色

$worksheet->getStyle('A1')->getFont()->getColor()->setARGB(Color::COLOR_DARKRED);

// 設置標題

$worksheet->setTitle($expTitle);

// 設置表格菜單

for ($i = 0; $i < $cellNum; $i++) {

$worksheet->setCellValue($cellName[$i] . (+2), $expCellName[$i][1]);

$worksheet->getStyle($cellName[$i] . (+2))->getFont()->setBold(true);

// 自動寬度

$worksheet->getColumnDimension($cellName[$i])->setAutoSize(true);

}

// 設置表格內容

for ($i = 0; $i < $dataNum; $i++) {

for ($j = 0; $j < $cellNum; $j++) {

$worksheet->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);

// 支持換行

if ($expCellName[$j][2] == 1) {

$worksheet->getStyle($cellName[$j] . ($i + 3))->getAlignment()->setWrapText(true);

}

}

}

// 設置列寬為自動

// $spreadsheet->getActiveSheet()->getDefaultColumnDimension()->setWidth(20);

// $worksheet->getDefaultColumnDimension()->setAutoSize(true);

// 設置行高

$worksheet->getDefaultRowDimension()->setRowHeight(20);

header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');//告訴瀏覽器輸出07Excel文件

//header('Content-Type:application/vnd.ms-excel');//告訴瀏覽器將要輸出Excel03版本文件

header('Content-Disposition: attachment;filename="'.$fileName.'.xlsx"');//告訴瀏覽器輸出瀏覽器名稱

header('Cache-Control: max-age=0');//禁止緩存

$writer = new Xlsx($spreadsheet);

$writer->save('php://output');

}

}

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

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

相關文章

php 不同時區時間轉換,在PHP中將DateTime字符串轉換為不同的時區

好吧,我有以下代碼$from "Asia/Manila";$to "UTC";$org_time new DateTime("2012-05-15 10:50:00");$org_time $org_time->format("Y-m-d H:i:s");$conv_time NULL;$userTimezone new DateTimeZone($from);$gmtTimezone new…

php iis ajax 無效,IIS7中Ajax.AjaxMethod無效的原因及解決方法

最近做用Ajax.AjaxMethod方法的時候&#xff0c;在asp.net的服務器下一切正常&#xff0c;用iis的時候&#xff0c;js中總是cs類找不到&#xff0c;我就郁悶了&#xff0c;折騰了大半天&#xff0c;終于找到錯誤原因了。因為我發布網站用的是iis7&#xff0c;所以在web.config位…

查看oracle監聽服務器,處理Oracle 監聽文件listener.log問題

如果連接時候變得較慢 查看Oracle日志記錄&#xff0c;可能是因為此文件太大&#xff0c;超過2G&#xff0c;需要定期清理&#xff0c;(如果多用戶&#xff0c;記得用root&#xff0c;可能沒權限)查看listener.log&#xff1f;find / -name listener.log經查看&#xff0c;竟然…

oracle添加偽列,Oracle偽列 - jifengtang的個人空間 - OSCHINA - 中文開源技術交流社區...

在oracle10g和下&#xff0c;偽列包括如下內容&#xff1a;lHierarchical Query Pseudocolumns分級查詢是oracle提供的遞歸查詢語法&#xff0c;在這里不做展開。只有在分級查詢下&#xff0c;才可以使用以下偽列&#xff1a;1.CONNECT_BY_ISCYCLE Pseudocolumn2.CONNECT_BY_IS…

美國oracle球場,美國體育館考察——美國體育產業是如何盈利的?

體育是美國一項較高利潤的產業&#xff0c;其發展規模、發展水平和效益都是世界一流的。美國體育館考察&#xff0c;主要考察美國體育產業的盈利模式和體育賽事的贊助模式以及球館的運營管理&#xff0c;并對比中美體育產業的差異&#xff0c;從中獲得先進的體育產業運營思維&a…

php集成環境怎么打開,PHP集成開發環境PhpStorm快速入門指南(二):打開一個項目?...

PhpStorm是一個輕量級且便捷的PHP IDE&#xff0c;其旨在提高用戶效率&#xff0c;可深刻理解用戶的編碼&#xff0c;提供智能代碼補全&#xff0c;快速導航以及即時錯誤檢查。可隨時幫助用戶對其編碼進行調整&#xff0c;運行單元測試或者提供可視化debug功能。PhpStorm 2019.…

如何查詢oracle最近報警信息,教你怎樣用Oracle方便地查看報警日志錯誤

在網上查了幾天的資料&#xff0c;嘗試綜合清除告警日志內容及建外部表的方式來解決這一問題。一&#xff1a;備份并清除告警日志內容將每天的告警日志備份好&#xff0c;然后進行清除。1:備份報警日志在$ORACLE_HOME/SID/bdump/ 目錄下&#xff0c;按日期備份alert_ORACLE_你…

計算機分php,計算機按照處理數據的形態分類,可以分為什么?

計算機按照處理數據的形態分類&#xff0c;可以分為&#xff1a;1、數字計算機&#xff0c;是以數字形式的量值在機器內部進行運算和存儲的電子計算機&#xff1b;2、模擬計算機&#xff0c;是根據相似原理&#xff0c;用一種連續變化的模擬量作為被運算的對象的計算機&#xf…

2.oracle物理結構,oracle實驗2oracle物理結構管理

oracle實驗2oracle物理結構管理 (6頁)本資源提供全文預覽&#xff0c;點擊全文預覽即可全文預覽,如果喜歡文檔就下載吧&#xff0c;查找使用更方便哦&#xff01;9.9 積分實驗2 oracle物理存儲結構管理、實驗目的1. 掌握物理結構的創建和修改方法2. 掌握表空間的存儲參數設置方…

linux mount 查看掛載目錄,Linux下使用mount來掛載設備到目錄

一般情況下直接mount 設備路徑 目錄路徑&#xff0c;就可以了。umount 設備名&#xff0c;就可以卸載這個設備了使用lsblk -f可以查看掛載的設備&#xff0c;以及這些設備的文件系統。roottao-PC:/boot# lsblk -fNAME FSTYPE LABEL UUID MOUNTPOINTsda├─sda1├─sda2 vfat SY…

centos7是哪種版本Linux,centos7怎么查看系統版本是不是7.2 7.5 7.6

CentOS的版本號信息一般存放在配置文件當中&#xff0c;在CentOS中&#xff0c;與其版本相關的配置文件中都有centos關鍵字&#xff0c;該文件一般存放在/etc/目錄下&#xff0c;所以說我們可以直接在該文件夾下搜索相關的文件。其中存放其版本配置信息的文件為“centos-releas…

linux6.0 安裝教程,CentOS 6.0安裝步驟

1&#xff0e;安裝引導選擇安裝或升級現有系統(Install or upgrade an existing system)&#xff1a;這個選項是默認的。 選擇此選項&#xff0c;安裝到您的計算機使用CentOS的圖形安裝程序的系統。2.檢測光盤介質可以選擇skip跳過3.選擇安裝過程中的語言這里選擇chinese中文簡…

LeetCode - Easy - 14. Longest Common Prefix

Topic String Description https://leetcode.com/problems/longest-common-prefix/ Write a function to find the longest common prefix string amongst an array of strings. If there is no common prefix, return an empty string “”. Example 1: Input: strs […

linux 虛函數調用性能,C++對象布局及多態實現探索之虛函數調用

我們再看看虛成員函數的調用。類C041中含有虛成員函數&#xff0c;它的定義如下&#xff1a;struct C041{C041() : c_(0x01) {}virtual void foo() { c_ 0x02; }char c_;};執行如下代碼&#xff1a;C041 obj;PRINT_DETAIL(C041, obj)PRINT_VTABLE_ITEM(obj, 0, 0)obj.foo();C0…

netflow流量分析工具 linux,Centos5/Linux安裝Nfdump和Nfsen圖形界面分析netflow數據

Nfdump是linux下netflow數據采集分析工具&#xff0c;Nfsen是基于nfdump是web界面工具&#xff0c;服務器需先安裝web服務器和php環境。安裝rrdtool及所需組件&#xff1a;yum install perl-rrdtool rrdtool rrdtool-devel rrdutils flex byacc安裝所需perl模塊&#xff1a;yum…

linux嵌入式平臺測試,protobuf-c 在arm linux 嵌入式平臺的使用 測試

關于什么是protobuf&#xff0c;網上搜搜一大堆&#xff0c;很多人用的都還是json&#xff0c;以為json是多種語言傳輸數據是萬能的&#xff0c;看完了protobuf的實現&#xff0c;就明白了簡單高效才是王道。1、首先寫一個.proto擴展名的文件json.proto&#xff0c;內容格式如下…

Linux gitpush錯誤,linux – GIT:無法推送(奇怪的配置問題)

我正在全新安裝Linux Mint.嘗試從任何存儲庫推送時,我收到以下錯誤&#xff1a;error: Malformed value for push.default: simpleerror: Must be one of nothing,matching,tracking or current.fatal: bad config file line 8 in /home/leng/.gitconfigfatal: Could not read …

linux+shell+func,Linux shell編程筆記總結

Linux Shell學習筆記簡介Linux系統的shell作為操作系統的外殼&#xff0c;為用戶提供使用操作系統的接口。它是命令語言、命令解釋程序及程序設計語言的統稱。shell是用戶和Linux內核之間的接口程序&#xff0c;如果把Linux內核想象成一個球體的中心&#xff0c;shell就是圍繞內…

linux版車機安裝步驟,RedHat Linux 9.0的安裝(詳細圖解安裝過程)

RedHat Linux版本:" b, t) b) b# }, t# z- fC& S$ x0 }) GRedHat Linux是目前世界上使用最多的Linux操作系統。因為它具備最好的圖形界面&#xff0c;無論是安裝、配置還是使用都十分方便&#xff0c;而且運行穩定&#xff0c;因此不論是新手還是老玩家都對它有很高的…

linux中網頁播放音樂,Linux_在Linux系統下播放網頁中的背景音樂技巧,在Linux中的firefox瀏覽許多網頁 - phpStudy...

在Linux系統下播放網頁中的背景音樂技巧在Linux中的firefox瀏覽許多網頁時&#xff0c;很多使用了基于WMP的背景音樂播放器&#xff0c;如部份baidu空間。但firefox默認不支持播放。在LINUX的源中&#xff0c;有一為kaffeine-mozilla-plugin&#xff0c;能在firefox中使用kaffe…