


Importation et exportation de données ThinkPHP6?: réalisation du traitement par lots de données
Aug 26, 2023 pm 08:04 PMImport et export de données ThinkPHP6?: réalisez un traitement par lots des données
Dans le développement réel, nous rencontrons souvent le besoin d'importer et d'exporter des données par lots, comme l'importation de données depuis des tableaux Excel vers une base de données, ou le transfert de données depuis un base de données dans une base de données. Les données sont exportées vers des fichiers Excel. De telles opérations peuvent améliorer l’efficacité du développement et réduire la charge de travail liée à la saisie manuelle des données. Cet article expliquera comment utiliser le framework ThinkPHP6 pour implémenter le traitement par lots des données, y compris des étapes spécifiques et des exemples de code pour l'importation et l'exportation de données.
1. Importation de données
- Préparation
Tout d'abord, vous devez installer la bibliothèque PHPExcel dans le projet pour traiter les fichiers Excel. Vous pouvez utiliser Composer pour installer PHPExcel et exécuter la commande suivante?:
composer require phpoffice/phpexcel
Une fois l'installation terminée, un répertoire fournisseur sera généré, qui contient les fichiers pertinents de la bibliothèque PHPExcel.
- Importer des fichiers Excel
Dans ThinkPHP6, vous pouvez utiliser la fonction request()
pour obtenir les fichiers téléchargés par les utilisateurs. Tout d'abord, créez une méthode dans le contr?leur pour gérer l'opération d'importation?: request()
函數(shù)獲取到用戶上傳的文件。首先在控制器中創(chuàng)建一個用于處理導(dǎo)入操作的方法:
public function import() { // 獲取上傳的文件 $file = request()->file('file'); // 移動到框架應(yīng)用根目錄/uploads/目錄下 $info = $file->validate(['size' => 1048576, 'ext' => 'xls,xlsx'])->move(ROOT_PATH . 'uploads/'); if ($info) { // 獲取上傳文件的路徑 $filename = $info->getSaveName(); // 處理Excel導(dǎo)入邏輯 // ... // 返回成功信息 return '數(shù)據(jù)導(dǎo)入成功!'; } else { // 返回錯誤信息 return $file->getError(); } }
上述代碼中,首先通過request()
函數(shù)獲取到上傳的文件,并進行合法性校驗,限制文件大小為1MB,并只允許上傳.xls和.xlsx格式的文件。然后使用move()
方法將文件移動到框架的uploads目錄下,并將文件名保存到$filename
變量中。
接下來,可以在導(dǎo)入邏輯中使用PHPExcel庫來讀取和處理Excel文件。以下是一個簡單的示例:
public function import() { // ... // 創(chuàng)建PHPExcel對象 $excel = new PHPExcel(); // 讀取Excel文件 $reader = PHPExcel_IOFactory::createReader('Excel2007'); $PHPExcel = $reader->load(ROOT_PATH . 'uploads/' . $filename); // 獲取第一個工作表 $sheet = $PHPExcel->getSheet(0); // 獲取總行數(shù) $totalRow = $sheet->getHighestRow(); // 遍歷每一行數(shù)據(jù) for ($i = 2; $i <= $totalRow; $i++) { // 獲取單元格數(shù)據(jù) $name = $sheet->getCell('A' . $i)->getValue(); $age = $sheet->getCell('B' . $i)->getValue(); // 處理數(shù)據(jù)插入操作 // ... } // ... }
上述代碼中,我們使用PHPExcel庫創(chuàng)建了一個PHPExcel對象,并使用createReader()
方法來讀取Excel文件。然后通過getSheet()
方法獲取第一個工作表的對象,使用getHighestRow()
方法獲取總行數(shù)。
接下來,通過遍歷每一行的數(shù)據(jù),使用getCell()
方法獲取指定單元格的值,并將數(shù)據(jù)插入數(shù)據(jù)庫中,完成導(dǎo)入操作。
二、數(shù)據(jù)導(dǎo)出
- 導(dǎo)出數(shù)據(jù)庫數(shù)據(jù)
首先,在控制器中創(chuàng)建一個用于處理導(dǎo)出操作的方法:
public function export() { // 查詢數(shù)據(jù)庫數(shù)據(jù) $data = Db::name('user')->select(); // 處理Excel導(dǎo)出邏輯 // ... }
上述代碼中,使用ThinkPHP6的查詢構(gòu)造器Db::name('user')->select()
查詢數(shù)據(jù)庫中的用戶數(shù)據(jù)。
- 導(dǎo)出為Excel文件
接下來,我們使用PHPExcel庫將數(shù)據(jù)導(dǎo)出為Excel文件:
public function export() { // ... // 創(chuàng)建PHPExcel對象 $excel = new PHPExcel(); // 設(shè)置工作表標題 $excel->getActiveSheet()->setTitle('用戶數(shù)據(jù)'); // 設(shè)置表頭 $excel->getActiveSheet()->setCellValue('A1', 'ID'); $excel->getActiveSheet()->setCellValue('B1', '姓名'); $excel->getActiveSheet()->setCellValue('C1', '年齡'); // 設(shè)置數(shù)據(jù)內(nèi)容 $row = 2; foreach($data as $item) { $excel->getActiveSheet()->setCellValue('A' . $row, $item['id']); $excel->getActiveSheet()->setCellValue('B' . $row, $item['name']); $excel->getActiveSheet()->setCellValue('C' . $row, $item['age']); $row++; } // 導(dǎo)出Excel文件 header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); header('Content-Disposition: attachment;filename="user_data.xlsx"'); header('Cache-Control: max-age=0'); $writer = PHPExcel_IOFactory::createWriter($excel, 'Excel2007'); $writer->save('php://output'); }
上述代碼中,我們創(chuàng)建了一個PHPExcel對象,并使用setTitle()
方法設(shè)置工作表的標題。然后使用setCellValue()
rrreee
request()
, et la légalité est vérifiée et le fichier est limité. La taille est de 1 Mo et seuls les fichiers au format .xls et .xlsx peuvent être téléchargés. Utilisez ensuite la méthode move()
pour déplacer le fichier vers le répertoire de téléchargement du framework et enregistrez le nom du fichier dans la variable $filename
. Ensuite, la bibliothèque PHPExcel peut être utilisée dans la logique d'importation pour lire et traiter le fichier Excel. Voici un exemple simple?: rrreee
Dans le code ci-dessus, nous utilisons la bibliothèque PHPExcel pour créer un objet PHPExcel et utilisons la méthodecreateReader()
pour lire le fichier Excel. Utilisez ensuite la méthode getSheet()
pour obtenir l'objet de la première feuille de calcul, et utilisez la méthode getHighestRow()
pour obtenir le nombre total de lignes. Ensuite, en parcourant les données de chaque ligne, utilisez la méthode getCell()
pour obtenir la valeur de la cellule spécifiée, et insérez les données dans la base de données pour terminer l'opération d'importation. ????2. Exportation de données??????Exporter les données de la base de données??????Tout d'abord, créez une méthode dans le contr?leur pour gérer l'opération d'exportation?: ??rrreee??Dans le code ci-dessus, utilisez le générateur de requêtes de ThinkPHP6 Db:: name(' user')->select()
Interroger les données utilisateur dans la base de données. ??????Exporter vers un fichier Excel??????Ensuite, nous utilisons la bibliothèque PHPExcel pour exporter les données vers un fichier Excel?: ??rrreee??Dans le code ci-dessus, nous créons un objet PHPExcel et utilisons setTitle()
La méthode définit le titre de la feuille de calcul. Utilisez ensuite la méthode setCellValue()
pour définir l'en-tête et le contenu des données. ????Enfin, envoyez le fichier Excel exporté au navigateur pour téléchargement en définissant l'en-tête de réponse. ????Résumé????Cet article explique comment utiliser le framework ThinkPHP6 pour implémenter le traitement par lots des données, y compris des étapes spécifiques et des exemples de code pour l'importation et l'exportation de données. En utilisant la bibliothèque PHPExcel, nous pouvons facilement traiter les fichiers Excel, améliorer l'efficacité du développement et réduire la charge de travail de saisie manuelle des données. J'espère que cet article vous sera utile et pourra jouer un r?le dans le développement réel. ??Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour exécuter le projet ThinkPHP, vous devez?: installer Composer?; utiliser Composer pour créer le projet?; entrer dans le répertoire du projet et exécuter php bin/console serve?; visiter http://localhost:8000 pour afficher la page d'accueil.

ThinkPHP dispose de plusieurs versions con?ues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

étapes pour exécuter ThinkPHP Framework localement?: Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un h?te virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

ECharts est une bibliothèque de graphiques open source puissante, flexible et personnalisable qui peut être utilisée pour la visualisation de données et l'affichage sur grand écran. à l’ère du Big Data, les fonctions d’exportation et de partage de données des graphiques statistiques sont devenues de plus en plus importantes. Cet article présentera comment implémenter les fonctions d'exportation et de partage de données de graphiques statistiques d'ECharts via l'interface Java, et fournira des exemples de code spécifiques. 1. Introduction à ECharts ECharts est une bibliothèque de visualisation de données basée sur JavaScript et Canvas open source par Baidu, avec des graphiques riches.

Comparaison des performances des frameworks Laravel et ThinkPHP?: ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Dans la vie quotidienne, nous avons souvent besoin de remplacer nos téléphones portables par des neufs. Lorsque nous achetons un tout nouveau téléphone mobile Huawei, la manière d'importer rapidement et facilement les données de l'ancien téléphone vers le nouveau téléphone est devenue une préoccupation pour de nombreux utilisateurs. Heureusement, les téléphones mobiles Huawei proposent une série de méthodes pratiques pour aider les utilisateurs à importer rapidement d'anciennes données de téléphone mobile vers de nouveaux téléphones mobiles en un seul clic, nous permettant ainsi de passer facilement à une nouvelle expérience de téléphone mobile. Tout d'abord, nous pouvons utiliser la fonction ? Transfert rapide ? fournie avec les téléphones mobiles Huawei pour obtenir une transmission rapide des données. Ouvrez les paramètres du nouveau téléphone et recherchez ??Quick

étapes d'installation de ThinkPHP?: Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.
