Maison cadre php Laravel laravel import excel chinois ne s'affiche pas

laravel import excel chinois ne s'affiche pas

May 20, 2023 pm 10:22 PM

Dans Laravel, utiliser Maatwebsite/Laravel-Excel est un moyen très pratique de traiter des fichiers Excel. Cependant, parfois lorsque le fichier Excel importé contient du chinois, Laravel ne parvient pas à afficher correctement les caractères chinois dans la base de données. Cet article explorera ce problème et proposera quelques solutions.

Description du problème

Lors de l'utilisation de Maatwebsite/Laravel-Excel pour importer un tableau dans l'application Laravel, il arrive parfois que les caractères chinois soient tronqués ou affichés de manière incorrecte. Ce problème se produit généralement dans les situations suivantes :

  1. Incompatibilité d'encodage de la base de données : si la méthode d'encodage de la base de données est incohérente avec la méthode d'encodage du fichier Excel, les caractères chinois seront endommagés.
  2. Erreur d'encodage du fichier Excel : si la méthode d'encodage dans le fichier Excel est incohérente avec la méthode d'encodage réelle, les caractères chinois seront également endommagés.

Solution

  1. Vérifiez l'encodage de la base de données

Dans Laravel, l'encodage de la base de données est lié au fichier AppServiceProvider.php. Vous pouvez définir l'encodage de la base de données dans ce fichier. Si vous utilisez une base de données MySQL, vous pouvez la définir dans ce fichier :

utilisez IlluminateSupportServiceProvider;
utilisez IlluminateSupportFacadesSchema;
class AppServiceProvider extends ServiceProvider
{

public function boot()
{
    Schema::defaultStringLength(191);
    DB::statement('SET NAMES utf8mb4');
    DB::statement('SET CHARACTER SET utf8mb4');
}
Copier après la connexion

}

Dans le code ci-dessus, nous avons défini l'encodage de la base de données sur utf8mb4 , définir le codage dans le fichier pour qu'il soit identique à celui du fichier Excel résoudra le problème.

  1. Vérifiez l'encodage du fichier Excel

Si la méthode d'encodage de votre fichier Excel est incohérente avec la méthode d'encodage réelle, le problème des caractères chinois tronqués se produira lors de l'importation. Par conséquent, avant d’importer le fichier Excel, nous devons nous assurer que le fichier Excel est correctement encodé. Un moyen simple est :

Avant d'ouvrir le fichier Excel, enregistrez-le en tant que fichier TXT puis importez le fichier TXT, cela garantira que l'encodage est correct.

Par exemple :

$reader = MaatwebsiteExcelExcel::load('excel.xls')->toCsv('excel.csv');
$csvData = file_get_contents('excel.csv');
$csvData = mb_convert_encoding ($csvData, 'UTF-8', 'UTF-8');
$csvFile = fopen('excel.csv', 'w');
fwrite($csvFile, $csvData);
fclose($csvFile ) ;
$reader = MaatwebsiteExcelExcel::load('excel.csv')->get();

Dans cet exemple, nous convertissons le fichier Excel en fichier CSV, puis le convertissons en encodage UTF-8. Veuillez noter que cette approche n'est pas la meilleure et que vous devrez peut-être procéder à des ajustements supplémentaires pour garantir l'exactitude de vos données.

Conclusion

Résoudre le problème des caractères chinois n'est pas une tâche facile. Cependant, après la discussion dans cet article, nous avons compris les solutions de base. Si vous rencontrez toujours des problèmes avec les erreurs d'importation de caractères chinois, veuillez continuer à vérifier l'encodage de votre base de données et l'encodage de votre fichier Excel et apporter les ajustements nécessaires.

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines 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 utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Comment utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Mar 17, 2025 pm 02:47 PM

L'article discute de la création et de la personnalisation des éléments d'interface utilisateur réutilisables dans Laravel à l'aide de composants, offrant les meilleures pratiques pour l'organisation et suggérant des packages améliorant.

Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Mar 14, 2025 pm 01:44 PM

L'article traite des meilleures pratiques pour déployer Laravel dans des environnements natifs du cloud, en se concentrant sur l'évolutivité, la fiabilité et la sécurité. Les problèmes clés incluent la conteneurisation, les microservices, la conception sans état et les stratégies d'optimisation.

Comment créer et utiliser des directives de lame personnalisées à Laravel? Comment créer et utiliser des directives de lame personnalisées à Laravel? Mar 17, 2025 pm 02:50 PM

L'article discute de la création et de l'utilisation des directives de lame personnalisées à Laravel pour améliorer les modèles. Il couvre la définition des directives, les utilisant dans des modèles et les gérer dans de grands projets, mettant en évidence des avantages tels que l'amélioration de la réutilisabilité du code et R

Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Mar 17, 2025 pm 02:38 PM

L'article discute de la création et de l'utilisation de règles de validation personnalisées dans Laravel, offrant des étapes pour les définir et les mettre en œuvre. Il met en évidence des avantages tels que la réutilisabilité et la spécificité et fournit des méthodes pour étendre le système de validation de Laravel.

Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Mar 17, 2025 pm 02:39 PM

La console artisanale de Laravel automatise des tâches comme la génération de code, l'exécution de migrations et la planification. Les commandes clés incluent la marque: contrôleur, migrer et db: graines. Les commandes personnalisées peuvent être créées pour des besoins spécifiques, améliorant l'efficacité du flux de travail.

Comment puis-je utiliser les fonctionnalités de routage de Laravel pour créer des URL adaptées au référencement? Comment puis-je utiliser les fonctionnalités de routage de Laravel pour créer des URL adaptées au référencement? Mar 17, 2025 pm 02:43 PM

L'article discute de l'utilisation du routage de Laravel pour créer des URL conviviales, couvrant les meilleures pratiques, des URL canoniques et des outils pour l'optimisation du référencement. Nombre de mots: 159

Comment utiliser les transactions de base de données dans Laravel pour assurer la cohérence des données? Comment utiliser les transactions de base de données dans Laravel pour assurer la cohérence des données? Mar 17, 2025 pm 02:37 PM

L'article discute de l'utilisation des transactions de base de données dans Laravel pour maintenir la cohérence des données, des méthodes de détail avec une façade DB et des modèles éloquents, les meilleures pratiques, la gestion des exceptions et les outils de surveillance et de débogage des transactions.

Quel est le meilleur, Django ou Laravel? Quel est le meilleur, Django ou Laravel? Mar 28, 2025 am 10:41 AM

Django et Laravel sont tous deux des frameworks à pile. Django convient aux développeurs Python et à la logique métier complexe, tandis que Laravel convient aux développeurs PHP et à la syntaxe élégante. 1.Django est basé sur Python et suit la philosophie "Battery-Complete", adaptée au développement rapide et à une grande concurrence. 2.Laravel est basé sur PHP, mettant l'accent sur l'expérience du développeur et convient aux projets de petite et moyenne taille.

See all articles