Dengan perkembangan pesat Internet, Excel telah menjadi salah satu alat penting dalam kerja pejabat harian untuk syarikat dan individu. Oleh itu, keupayaan Excel untuk mengimport dan mengeksport telah menjadi bahagian penting dalam banyak aplikasi. Bagaimana untuk menggunakan ThinkPHP6 untuk melaksanakan import dan eksport Excel? Di bawah, artikel ini akan memperkenalkannya kepada anda secara terperinci.
1. Pengesahan persekitaran sistem ThinkPHP6
Untuk menggunakan ThinkPHP6 untuk melaksanakan import dan eksport Excel, anda perlu memenuhi keperluan persekitaran sistem terlebih dahulu. Dalam ThinkPHP6, anda boleh menggunakan komposer untuk memasang perpustakaan phpoffice/phpspreadsheet untuk melaksanakan fungsi pemprosesan Excel. Jalankan arahan berikut dalam baris arahan untuk memasang:
composer require phpoffice/phpspreadsheet
Selepas pemasangan, perkenalkan PhpOfficePhpSpreadsheetSpreadsheet dan PhpOfficePhpSpreadsheetWriterXlsx pustaka kelas kami dalam lapisan kod pengawal ini guna.
2. Eksport Excel
Menggunakan ThinkPHP6 untuk melaksanakan eksport Excel, anda perlu mengimport data ke dalam Excel terlebih dahulu. Kita boleh menulis kod yang sepadan dalam lapisan pengawal seperti yang diperlukan. Sebagai contoh, apabila mengeksport maklumat pelajar, anda boleh mendapatkan maklumat yang berkaitan dengan menanyakan pangkalan data.
use appcommonmodelStudent; public function export() { $students = Student::all(); }
Pengepala jadual Excel ialah bahagian yang sangat penting. Untuk menjadikan pengepala jadual Excel jelas, kita boleh menulis kod untuk menjana maklumat pengepala jadual. Dalam kod di bawah, kami menggunakan gelung untuk mencapai ini.
$spreadsheet = new Spreadsheet(); $sheet = $spreadsheet->getActiveSheet(); $sheet->setTitle('学生信息表'); $sheet->setCellValue('A1', '序号'); $sheet->setCellValue('B1', '学号'); $sheet->setCellValue('C1', '姓名'); $sheet->setCellValue('D1', '性别'); $sheet->setCellValue('E1', '日期');
Seterusnya, tulis data yang diperoleh ke dalam jadual Excel. Gelung data dan tulis maklumat setiap pelajar ke dalam jadual secara bergilir-gilir.
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); }
Akhir sekali, keluarkan dan simpan jadual Excel yang dijana secara setempat. Dalam kod di bawah, kami menggunakan penulis untuk menyimpan jadual Excel dalam format .xlsx dan mengeluarkannya ke penyemak imbas.
$writer = new Xlsx($spreadsheet); $filename = "学生信息表.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();
3. Import Excel
Selain mengeksport Excel, ThinkPHP6 juga boleh melaksanakan fungsi import Excel. Seterusnya, kami akan memperkenalkan kepada anda cara melaksanakan import Excel dalam ThinkPHP6.
Sebelum mengimport Excel, kita perlu memuat naik fail Excel terlebih dahulu. Di sini, kami menggunakan perpustakaan kelas muat naik fail yang disertakan dengan ThinkPHP6. Selepas muat naik berjaya, gunakan kaedah dalam perpustakaan kelas PhpOfficePhpSpreadsheetIOFactory untuk membaca data dalam fail Excel yang dimuat naik.
use thinkacadeFilesystem; $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 = [];
Selepas mendapat data jadual Excel, kita perlu melintasi data dan menggunakan tatasusunan untuk menyimpan setiap baris data dalam jadual 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; }
Akhir sekali, kami mengimport data dalam jadual Excel ke dalam pangkalan data. Di sini, kami menggunakan operasi ORM yang disertakan dengan ThinkPHP6 untuk menyimpan data ke dalam jadual pangkalan data.
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' => '操作成功']);
Ringkasan
Artikel ini memperincikan cara menggunakan ThinkPHP6 untuk melaksanakan fungsi import dan eksport Excel. Dengan menggunakan perpustakaan kelas PhpOfficePhpSpreadsheet, kami boleh menyelesaikan operasi berkaitan Excel dengan mudah. Fungsi import dan eksport Excel digunakan secara meluas dalam sistem pengurusan perusahaan Memahami dan menguasai kemahiran berkaitan akan sangat membantu pembangun.
Atas ialah kandungan terperinci Cara menggunakan ThinkPHP6 untuk melaksanakan import dan eksport Excel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!