亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 php框架 ThinkPHP 如何使用ThinkPHP6實(shí)作Excel導(dǎo)入導(dǎo)出

如何使用ThinkPHP6實(shí)作Excel導(dǎo)入導(dǎo)出

Jun 21, 2023 pm 06:01 PM
thinkphp excel導(dǎo)入 excel匯出

隨著網(wǎng)路的快速發(fā)展,Excel已成為公司和個人日常辦公室中重要的工具之一。因此,Excel導(dǎo)入導(dǎo)出的功能已經(jīng)成為許多應(yīng)用程式的必要組成部分。如何使用ThinkPHP6實(shí)作Excel導(dǎo)入導(dǎo)出呢?下面,本文將為您詳細(xì)介紹。

一、ThinkPHP6系統(tǒng)環(huán)境驗(yàn)證

使用ThinkPHP6實(shí)作Excel導(dǎo)入?yún)R出,首先需要滿足系統(tǒng)環(huán)境需求。在ThinkPHP6中,可以使用composer安裝phpoffice/phpspreadsheet函式庫,實(shí)作Excel處理功能。在命令列中執(zhí)行以下命令進(jìn)行安裝:

composer require phpoffice/phpspreadsheet

安裝完畢後,在controller層中引入PhpOfficePhpSpreadsheetSpreadsheet和PhpOfficePhpPhpOfficePhplssheetWriterSpcxWriter庫將在我們的後面程式碼中使用。

二、Excel匯出

  1. 匯出Excel資料

#使用ThinkPHP6實(shí)作Excel匯出,首先需要將資料匯入Excel。我們可以根據(jù)需要,在controller層中編寫相應(yīng)的程式碼。例如,在匯出學(xué)生資訊時,可以透過查詢資料庫取得相關(guān)資訊。

use appcommonmodelStudent;

public function export()
{
    $students = Student::all();
}
  1. 設(shè)定Excel表格的頭部

Excel的表格頭部是非常重要的一部分。為了使Excel表格的頭部清晰明了,我們可以編寫程式碼來產(chǎn)生表格的頭部資訊。在下面的程式碼中,我們使用了循環(huán)來實(shí)現(xiàn)。

$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
$sheet->setTitle('學(xué)生信息表');

$sheet->setCellValue('A1', '序號');
$sheet->setCellValue('B1', '學(xué)號');
$sheet->setCellValue('C1', '姓名');
$sheet->setCellValue('D1', '性別');
$sheet->setCellValue('E1', '日期');
  1. 將資料寫入Excel表格

接下來,將取得的資料寫入Excel表格中。循環(huán)遍歷數(shù)據(jù),將每個學(xué)生的資料依序?qū)懭氡砀裰小?

foreach ($students as $key => $item) {
    $num = $key + 2;
    $sheet->setCellValue('A' . $num, $num - 1);
    $sheet->setCellValue('B' . $num, $item->number);
    $sheet->setCellValue('C' . $num, $item->name);
    $sheet->setCellValue('D' . $num, $item->sex);
    $sheet->setCellValue('E' . $num, $item->date);
}
  1. 將Excel表格輸出並儲存到本機(jī)

最後,將產(chǎn)生的Excel表格輸出並儲存到本機(jī)。在下面的程式碼中,我們使用writer來將Excel表格儲存為.xlsx格式並輸出到瀏覽器中。

$writer = new Xlsx($spreadsheet);
$filename = "學(xué)生信息表.xlsx";
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename=' . $filename);
header('Cache-Control: max-age=0');
$writer->save('php://output');
exit();

三、Excel導(dǎo)入

除了匯出Excel,ThinkPHP6還可以實(shí)現(xiàn)Excel的導(dǎo)入功能。接下來,我們將為您介紹ThinkPHP6中實(shí)作Excel導(dǎo)入的方法。

  1. 上傳Excel檔案並讀取資料

在匯入Excel之前,我們需要先上傳Excel檔案。在這裡,我們使用了ThinkPHP6自備的文件上傳類別庫。上傳成功之後,使用PhpOfficePhpSpreadsheetIOFactory類別庫中的方法,讀取上傳的Excel檔案中的資料。

use thinkacadeFilesystem;

$uploadFile = request()->file('file');
$saveName = Filesystem::disk('public')->putFile('excel', $uploadFile);
$filePath = Filesystem::disk('public')->path($saveName);

$spreadsheet = PhpOfficePhpSpreadsheetIOFactory::load($filePath);
$sheet = $spreadsheet->getActiveSheet();
$highestRow = $sheet->getHighestRow();
$data = [];
  1. 遍歷Excel表格並得到資料

取得到Excel表格資料後,我們需要將資料遍歷一遍,使用陣列保存Excel表格的每一行資料。

for($i = 2; $i <= $highestRow; $i++){
    $item['number'] = $sheet->getCellByColumnAndRow(1, $i)->getValue();
    $item['name'] = $sheet->getCellByColumnAndRow(2, $i)->getValue();
    $item['sex'] = $sheet->getCellByColumnAndRow(3, $i)->getValue();
    $item['date'] = date('Y-m-d H:i:s',$sheet->getCellByColumnAndRow(4, $i)->getValue() - 25569)*86400;
    $data[] = $item;
}
  1. 將Excel表格匯入到資料庫中

最後,我們將Excel表格中的資料匯入到資料庫中。在這裡,我們使用ThinkPHP6自帶的ORM操作,將資料保存到資料庫表中。

use appcommonmodelStudent;

Db::startTrans();
try {
    Student::insertAll($data);
    Db::commit();
} catch (Exception $e) {
    Db::rollback();
    return json(['code' => '500', 'msg' => '操作失敗']);
}
return json(['code' => '200', 'msg' => '操作成功']);

總結(jié)

本文詳細(xì)介紹如何使用ThinkPHP6實(shí)作Excel匯入?yún)R出功能。透過使用PhpOfficePhpSpreadsheet類別庫,我們可以輕鬆地完成Excel相關(guān)的操作。 Excel導(dǎo)入?yún)R出功能在企業(yè)管理系統(tǒng)中用到非常廣泛,理解和掌握相關(guān)技能將對開發(fā)者有很大的幫助。

以上是如何使用ThinkPHP6實(shí)作Excel導(dǎo)入導(dǎo)出的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
thinkphp專案怎麼運(yùn)行 thinkphp專案怎麼運(yùn)行 Apr 09, 2024 pm 05:33 PM

執(zhí)行 ThinkPHP 專案需要:安裝 Composer;使用 Composer 建立專案;進(jìn)入專案目錄,執(zhí)行 php bin/console serve;造訪 http://localhost:8000 查看歡迎頁面。

thinkphp有幾個版本 thinkphp有幾個版本 Apr 09, 2024 pm 06:09 PM

ThinkPHP 擁有多個版本,針對不同 PHP 版本而設(shè)計(jì)。主要版本包括 3.2、5.0、5.1 和 6.0,而次要版本用於修復(fù) bug 和提供新功能。目前最新穩(wěn)定版本為 ThinkPHP 6.0.16。在選擇版本時,需考慮 PHP 版本、功能需求和社群支援。建議使用最新穩(wěn)定版本以獲得最佳性能和支援。

thinkphp怎麼運(yùn)行 thinkphp怎麼運(yùn)行 Apr 09, 2024 pm 05:39 PM

ThinkPHP Framework 的本機(jī)運(yùn)作步驟:下載並解壓縮 ThinkPHP Framework 到本機(jī)目錄。建立虛擬主機(jī)(可選),指向 ThinkPHP 根目錄。配置資料庫連線參數(shù)。啟動 Web 伺服器。初始化 ThinkPHP 應(yīng)用程式。存取 ThinkPHP 應(yīng)用程式 URL 運(yùn)行。

laravel和thinkphp哪個好 laravel和thinkphp哪個好 Apr 09, 2024 pm 03:18 PM

Laravel 和 ThinkPHP 框架的效能比較:ThinkPHP 效能通常優(yōu)於 Laravel,專注於最佳化和快取。 Laravel 性能良好,但對於複雜應(yīng)用程序,ThinkPHP 可能更適合。

thinkphp怎麼安裝 thinkphp怎麼安裝 Apr 09, 2024 pm 05:42 PM

ThinkPHP 安裝步驟:準(zhǔn)備 PHP、Composer、MySQL 環(huán)境。使用 Composer 建立專案。安裝 ThinkPHP 框架及相依性。配置資料庫連線。產(chǎn)生應(yīng)用程式碼。啟動應(yīng)用程式並造訪 http://localhost:8000。

thinkphp效能怎麼樣 thinkphp效能怎麼樣 Apr 09, 2024 pm 05:24 PM

ThinkPHP 是一款高效能的 PHP 框架,具備快取機(jī)制、程式碼最佳化、平行處理和資料庫最佳化等優(yōu)勢。官方性能測試顯示,它每秒可處理超過 10,000 個請求,實(shí)際應(yīng)用中被廣泛用於京東商城、攜程網(wǎng)等大型網(wǎng)站和企業(yè)系統(tǒng)。

開發(fā)建議:如何利用ThinkPHP框架進(jìn)行API開發(fā) 開發(fā)建議:如何利用ThinkPHP框架進(jìn)行API開發(fā) Nov 22, 2023 pm 05:18 PM

開發(fā)建議:如何利用ThinkPHP框架進(jìn)行API開發(fā)隨著網(wǎng)際網(wǎng)路的不斷發(fā)展,API(ApplicationProgrammingInterface)的重要性也日益凸顯。 API是不同應(yīng)用程式之間進(jìn)行通訊的橋樑,它可以實(shí)現(xiàn)資料共享、功能呼叫等操作,為開發(fā)者提供了相對簡單且快速的開發(fā)方式。而ThinkPHP框架作為一款優(yōu)秀的PHP開發(fā)框架,具有高效能、可擴(kuò)展且易用

開發(fā)建議:如何利用ThinkPHP框架實(shí)現(xiàn)非同步任務(wù) 開發(fā)建議:如何利用ThinkPHP框架實(shí)現(xiàn)非同步任務(wù) Nov 22, 2023 pm 12:01 PM

《開發(fā)建議:如何利用ThinkPHP框架實(shí)現(xiàn)非同步任務(wù)》隨著網(wǎng)路技術(shù)的快速發(fā)展,Web應(yīng)用程式對於處理大量並發(fā)請求和複雜業(yè)務(wù)邏輯的需求也越來越高。為了提高系統(tǒng)的效能和使用者體驗(yàn),開發(fā)人員常常會考慮利用非同步任務(wù)來執(zhí)行一些耗時操作,例如發(fā)送郵件、處理文件上傳、產(chǎn)生報表等。在PHP領(lǐng)域,ThinkPHP框架作為一個流行的開發(fā)框架,提供了一些便捷的方式來實(shí)現(xiàn)非同步任務(wù)。

See all articles