Rumah rangka kerja php ThinkPHP Cara menggunakan ThinkPHP6 untuk melaksanakan import dan eksport Excel

Cara menggunakan ThinkPHP6 untuk melaksanakan import dan eksport Excel

Jun 21, 2023 pm 06:01 PM
thinkphp import cemerlang eksport cemerlang

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

  1. Eksport data 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();
}
Salin selepas log masuk
  1. Tetapkan pengepala jadual Excel

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', '日期');
Salin selepas log masuk
  1. Tulis data ke dalam jadual Excel

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);
}
Salin selepas log masuk
  1. Output dan simpan jadual Excel secara setempat

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();
Salin selepas log masuk

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.

  1. Muat naik fail Excel dan baca data

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 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 = [];
Salin selepas log masuk
  1. Lintas jadual Excel dan dapatkan 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;
}
Salin selepas log masuk
  1. Import jadual Excel ke dalam pangkalan data

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' => '操作成功']);
Salin selepas log masuk

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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menjalankan projek thinkphp Bagaimana untuk menjalankan projek thinkphp Apr 09, 2024 pm 05:33 PM

Untuk menjalankan projek ThinkPHP, anda perlu: memasang Komposer untuk mencipta projek, masukkan direktori projek dan laksanakan php bin/console serve;

Terdapat beberapa versi thinkphp Terdapat beberapa versi thinkphp Apr 09, 2024 pm 06:09 PM

ThinkPHP mempunyai berbilang versi yang direka untuk versi PHP yang berbeza. Versi utama termasuk 3.2, 5.0, 5.1 dan 6.0, manakala versi kecil digunakan untuk membetulkan pepijat dan menyediakan ciri baharu. Versi stabil terkini ialah ThinkPHP 6.0.16. Apabila memilih versi, pertimbangkan versi PHP, keperluan ciri dan sokongan komuniti. Adalah disyorkan untuk menggunakan versi stabil terkini untuk prestasi dan sokongan terbaik.

Bagaimana untuk menjalankan thinkphp Bagaimana untuk menjalankan thinkphp Apr 09, 2024 pm 05:39 PM

Langkah-langkah untuk menjalankan ThinkPHP Framework secara setempat: Muat turun dan nyahzip ThinkPHP Framework ke direktori tempatan. Buat hos maya (pilihan) yang menunjuk ke direktori akar ThinkPHP. Konfigurasikan parameter sambungan pangkalan data. Mulakan pelayan web. Mulakan aplikasi ThinkPHP. Akses URL aplikasi ThinkPHP dan jalankannya.

Cadangan pembangunan: Cara menggunakan rangka kerja ThinkPHP untuk melaksanakan tugas tak segerak Cadangan pembangunan: Cara menggunakan rangka kerja ThinkPHP untuk melaksanakan tugas tak segerak Nov 22, 2023 pm 12:01 PM

"Cadangan Pembangunan: Cara Menggunakan Rangka Kerja ThinkPHP untuk Melaksanakan Tugas Asynchronous" Dengan perkembangan pesat teknologi Internet, aplikasi Web mempunyai keperluan yang semakin tinggi untuk mengendalikan sejumlah besar permintaan serentak dan logik perniagaan yang kompleks. Untuk meningkatkan prestasi sistem dan pengalaman pengguna, pembangun sering mempertimbangkan untuk menggunakan tugas tak segerak untuk melaksanakan beberapa operasi yang memakan masa, seperti menghantar e-mel, memproses muat naik fail, menjana laporan, dsb. Dalam bidang PHP, rangka kerja ThinkPHP, sebagai rangka kerja pembangunan yang popular, menyediakan beberapa cara mudah untuk melaksanakan tugas tak segerak.

Mana yang lebih baik, laravel atau thinkphp? Mana yang lebih baik, laravel atau thinkphp? Apr 09, 2024 pm 03:18 PM

Perbandingan prestasi rangka kerja Laravel dan ThinkPHP: ThinkPHP umumnya berprestasi lebih baik daripada Laravel, memfokuskan pada pengoptimuman dan caching. Laravel berfungsi dengan baik, tetapi untuk aplikasi yang kompleks, ThinkPHP mungkin lebih sesuai.

Bagaimana untuk memasang thinkphp Bagaimana untuk memasang thinkphp Apr 09, 2024 pm 05:42 PM

Langkah pemasangan ThinkPHP: Sediakan persekitaran PHP, Komposer dan MySQL. Buat projek menggunakan Komposer. Pasang rangka kerja dan kebergantungan ThinkPHP. Konfigurasikan sambungan pangkalan data. Hasilkan kod aplikasi. Lancarkan aplikasi dan lawati http://localhost:8000.

Bagaimanakah prestasi thinkphp? Bagaimanakah prestasi thinkphp? Apr 09, 2024 pm 05:24 PM

ThinkPHP ialah rangka kerja PHP berprestasi tinggi dengan kelebihan seperti mekanisme caching, pengoptimuman kod, pemprosesan selari dan pengoptimuman pangkalan data. Ujian prestasi rasmi menunjukkan bahawa ia boleh mengendalikan lebih daripada 10,000 permintaan sesaat, dan digunakan secara meluas dalam tapak web dan sistem perusahaan berskala besar seperti JD.com dan Ctrip dalam aplikasi praktikal.

Cadangan pembangunan: Cara menggunakan rangka kerja ThinkPHP untuk pembangunan API Cadangan pembangunan: Cara menggunakan rangka kerja ThinkPHP untuk pembangunan API Nov 22, 2023 pm 05:18 PM

Cadangan pembangunan: Cara menggunakan rangka kerja ThinkPHP untuk pembangunan API Dengan pembangunan berterusan Internet, kepentingan API (Antara Muka Pengaturcaraan Aplikasi) telah menjadi semakin menonjol. API ialah jambatan untuk komunikasi antara aplikasi yang berbeza Ia boleh merealisasikan perkongsian data, panggilan fungsi dan operasi lain, dan menyediakan pembangun kaedah pembangunan yang agak mudah dan pantas. Sebagai rangka kerja pembangunan PHP yang sangat baik, rangka kerja ThinkPHP adalah cekap, berskala dan mudah digunakan.

See all articles