Maison >développement back-end >Problème PHP >Comment résoudre le problème tronqué de php fgetcsv

Comment résoudre le problème tronqué de php fgetcsv

藏色散人
藏色散人original
2020-07-27 10:06:083985parcourir

php fgetcsv est tronqué car le fichier csv importé est enregistré en codage ansi. La solution consiste à définir le codage correspondant à l'environnement du système d'exploitation chinois sur "gbk", c'est-à-dire à modifier manuellement le codage des caractères du navigateur en. "gbk" fera l'affaire.

Comment résoudre le problème tronqué de php fgetcsv

Recommandé : "Tutoriel PHP"

php utilise fgetcsv pour lire les fichiers csv et résout le problème Méthode des caractères tronqués

De manière générale, la rencontre de caractères tronqués en PHP est principalement due à des problèmes d'encodage. Nous analysons ici les causes et les solutions des caractères tronqués lorsque fgetcsv lit des fichiers csv.

L'exemple est le suivant :

Le code est le suivant :

function get_csv_contents( $file_target ){
 $handle  = fopen( $file_target, 'r');
 while ($data = fgetcsv($handle, 1000, ",")) {
 
  $num = count($data);
  echo "<p> $num fields in line $row: <br>n";
  $row++;
  for ($c=0; $c < $num; $c++) {
   echo $data[$c]. "<br>n";;
   /*echo getUTFString($data[$c])*/
  }
 }
 fclose($handle);
}

Le fichier csv importé est enregistré en codage ansi. Pour l'environnement du système d'exploitation chinois, le correspondant. l'un devrait être le codage gbk. Pass Modification manuelle du codage des caractères du navigateur en gbk, les caractères tronqués ont disparu et les ajustements suivants ont été effectués.

Le code est le suivant :

$data = eval(&#39;return &#39;.iconv(&#39;gbk&#39;,&#39;utf-8&#39;,var_export($data,true)).&#39;;&#39;);

$data est le tableau qui doit être converti en codage.

Supplément : LINUX FGETCSV lit les données GBK avec des caractères tronqués

Lorsque le système Linux utilise les paramètres par défaut, lorsque le fichier au format gbk csv est traité sur le serveur Linux, il apparaîtra tronqué. personnages.

La solution est :

Utilisez la fonction setlocale pour définir les variables d'environnement. Par exemple, pour définir les paramètres régionaux à l'aide de gb, vous pouvez utiliser l'instruction suivante avant fgetcsv.

Le code est le suivant :

setlocale(LC_ALL,array(&#39;zh_CN.gbk&#39;,&#39;zh_CN.gb2312&#39;,&#39;zh_CN.gb18030&#39;));

Quels paramètres régionaux sont utilisés spécifiquement ? Vous pouvez utiliser la commande Linux locale -a pour vérifier quels

le système prend en charge.

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:
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