Maison cadre php PensezPHP Importation et exportation de données ThinkPHP6 : réalisation du traitement par lots de données

Importation et exportation de données ThinkPHP6 : réalisation du traitement par lots de données

Aug 26, 2023 pm 08:04 PM
thinkphp 数据导入 数据导出

Importation et exportation de données ThinkPHP6 : réalisation du traitement par lots de données

Import 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

  1. 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
Copier après la connexion

Une fois l'installation terminée, un répertoire fournisseur sera généré, qui contient les fichiers pertinents de la bibliothèque PHPExcel.

  1. 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()函数获取到用户上传的文件。首先在控制器中创建一个用于处理导入操作的方法:

public function import()
{
    // 获取上传的文件
    $file = request()->file('file');
    
    // 移动到框架应用根目录/uploads/目录下
    $info = $file->validate(['size' => 1048576, 'ext' => 'xls,xlsx'])->move(ROOT_PATH . 'uploads/');

    if ($info) {
        // 获取上传文件的路径
        $filename = $info->getSaveName();
        
        // 处理Excel导入逻辑
        // ...
        
        // 返回成功信息
        return '数据导入成功!';
    } else {
        // 返回错误信息
        return $file->getError();
    }
}
Copier après la connexion

上述代码中,首先通过request()函数获取到上传的文件,并进行合法性校验,限制文件大小为1MB,并只允许上传.xls和.xlsx格式的文件。然后使用move()方法将文件移动到框架的uploads目录下,并将文件名保存到$filename变量中。

接下来,可以在导入逻辑中使用PHPExcel库来读取和处理Excel文件。以下是一个简单的示例:

public function import()
{
    // ...

    // 创建PHPExcel对象
    $excel = new PHPExcel();

    // 读取Excel文件
    $reader = PHPExcel_IOFactory::createReader('Excel2007');
    $PHPExcel = $reader->load(ROOT_PATH . 'uploads/' . $filename);

    // 获取第一个工作表
    $sheet = $PHPExcel->getSheet(0);

    // 获取总行数
    $totalRow = $sheet->getHighestRow();

    // 遍历每一行数据
    for ($i = 2; $i <= $totalRow; $i++) {
        // 获取单元格数据
        $name = $sheet->getCell('A' . $i)->getValue();
        $age = $sheet->getCell('B' . $i)->getValue();

        // 处理数据插入操作
        // ...
    }

    // ...
}
Copier après la connexion

上述代码中,我们使用PHPExcel库创建了一个PHPExcel对象,并使用createReader()方法来读取Excel文件。然后通过getSheet()方法获取第一个工作表的对象,使用getHighestRow()方法获取总行数。

接下来,通过遍历每一行的数据,使用getCell()方法获取指定单元格的值,并将数据插入数据库中,完成导入操作。

二、数据导出

  1. 导出数据库数据

首先,在控制器中创建一个用于处理导出操作的方法:

public function export()
{
    // 查询数据库数据
    $data = Db::name('user')->select();
    
    // 处理Excel导出逻辑
    // ...
}
Copier après la connexion

上述代码中,使用ThinkPHP6的查询构造器Db::name('user')->select()查询数据库中的用户数据。

  1. 导出为Excel文件

接下来,我们使用PHPExcel库将数据导出为Excel文件:

public function export()
{
    // ...
    
    // 创建PHPExcel对象
    $excel = new PHPExcel();
    
    // 设置工作表标题
    $excel->getActiveSheet()->setTitle('用户数据');

    // 设置表头
    $excel->getActiveSheet()->setCellValue('A1', 'ID');
    $excel->getActiveSheet()->setCellValue('B1', '姓名');
    $excel->getActiveSheet()->setCellValue('C1', '年龄');

    // 设置数据内容
    $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++;
    }

    // 导出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');
}
Copier après la connexion

上述代码中,我们创建了一个PHPExcel对象,并使用setTitle()方法设置工作表的标题。然后使用setCellValue()rrreee

Dans le code ci-dessus, le fichier téléchargé est d'abord obtenu via la fonction 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éthode createReader() 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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment exécuter le projet thinkphp Comment exécuter le projet thinkphp Apr 09, 2024 pm 05:33 PM

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.

Il existe plusieurs versions de thinkphp Il existe plusieurs versions de thinkphp Apr 09, 2024 pm 06:09 PM

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.

Interface ECharts et Java : Comment exporter et partager des données de graphiques statistiques Interface ECharts et Java : Comment exporter et partager des données de graphiques statistiques Dec 17, 2023 am 08:44 AM

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.

Guide complet pour importer des données d'un ancien téléphone vers un nouveau téléphone (migrer rapidement les anciennes données du téléphone vers un nouveau téléphone pour une conversion transparente) Guide complet pour importer des données d'un ancien téléphone vers un nouveau téléphone (migrer rapidement les anciennes données du téléphone vers un nouveau téléphone pour une conversion transparente) Feb 02, 2024 pm 06:36 PM

Les téléphones portables sont devenus un élément indispensable de la vie des gens dans la société moderne. Lorsque nous achetons un nouveau téléphone, le transfert transparent de données importantes de l'ancien téléphone vers le nouveau téléphone est l'un des problèmes ennuyeux. Pour vous aider à accomplir cette tâche facilement, ce guide vous présentera quelques méthodes simples et efficaces. Sauvegarde des anciennes données du téléphone Assurez-vous d'abord d'avoir sauvegardé toutes les données de votre ancien téléphone avant de commencer toute migration de données. Une sauvegarde informatique ou des outils de sauvegarde spécialisés peuvent être utilisés pour assurer la sécurité de vos données via des services de stockage cloud. Synchronisez les données à l'aide de services de stockage cloud tels que iCloud d'Apple et Google Drive d'Android. De nombreux smartphones modernes proposent des services de stockage cloud. Données importantes telles que photos, mémos, etc., connectez-vous et

Comment exécuter thinkphp Comment exécuter thinkphp Apr 09, 2024 pm 05:39 PM

É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.

Un clic pour le faire ! Comment importer rapidement des données d'anciens téléphones mobiles vers des téléphones mobiles Huawei Un clic pour le faire ! Comment importer rapidement des données d'anciens téléphones mobiles vers des téléphones mobiles Huawei Mar 22, 2024 pm 09:51 PM

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

Lequel est le meilleur, Laravel ou thinkphp ? Lequel est le meilleur, Laravel ou thinkphp ? Apr 09, 2024 pm 03:18 PM

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é.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Nov 22, 2023 pm 12:01 PM

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

See all articles