IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

exporter un fichier avec des décimals


Sujet :

Langage PHP

  1. #1
    Membre actif
    Homme Profil pro
    électronicien
    Inscrit en
    Octobre 2006
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : électronicien
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 225
    Points : 236
    Points
    236
    Par défaut exporter un fichier avec des décimals
    Bonjour.
    J'extrais des données mysql que je veux exporter dans une page calc. Le problème générique est bien sur "les décimals". Mysql possède un point et les pages de calcul veulent une virgule.
    J'ai donc fais ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
       $row    = mysql_fetch_assoc($DBexport);
        if(!$row){ jsalert( "le fichier Mysql ne peut pas être lu ou est vide"); return false; }
    
        for($i=0;$i< mysql_num_fields($DBexport);$i++)
            if(mysql_field_type($DBexport,$i)== 'int'|mysql_field_type($DBexport,$i)== 'float'|mysql_field_type($DBexport,$i)== 'tinyint'|
               mysql_field_type($DBexport,$i)== 'decimal')
                    $row[$i]= numberformat($row[$i],2,',','');
    
    
        fputcsv($handle, array_keys($row), ';');   // liste des titres de colonne
    
        do
        {
        	fputcsv($handle, $row, ';');            // on commence à remplir le tableau
        }
    
        while($row = mysql_fetch_assoc($DBexport));
        fputcsv($handle, $row, ';');                // on fini le remplissage du tableau
    Ca bloque sans raison dans la partie en gras, pourtant il me semblait être cohérent. Serais je tombé sur quelque chose d'incompatible ?
    Débusqueur de bug et chercheur en améliorations

  2. #2
    Membre émérite
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Points : 2 969
    Points
    2 969
    Par défaut
    Bonjour,

    Pour effectuer un ou logique, il faut utiliser le double pipe : || => http://php.net/manual/fr/language.operators.logical.php

    Le simple pipe, |, correspond à l'opérateur sur les bits => http://www.php.net/manual/fr/languag...rs.bitwise.php
    Si vous ne pouvez expliquer un concept à un enfant de six ans, c'est que vous ne le comprenez pas complètement. Albert EINSTEIN

    F.A.Q. : Java, PHP, (X)HTML / CSS

    N'oubliez pas de cliquer sur le bouton Résolu en bas de page quand vous avez obtenu une solution à votre problème

  3. #3
    Membre actif
    Homme Profil pro
    électronicien
    Inscrit en
    Octobre 2006
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : électronicien
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 225
    Points : 236
    Points
    236
    Par défaut
    Merci @Nesmontou de ce détail intéressant. Je l'ai corrigé mais le problème demeure.
    La ligne qui bloque est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     $row[$i]= numberformat($row[$i],2,',','');
    mysql_fetch_assoc( ) doit normalement créer un tableau associatif. (Je gère mal)
    Ma fonction utilise plusieurs type de tableau, je ne peux pas donner un nom spécifique ici.
    ex: $row["userid"]; C'est pourquoi un numéro m'allait bien.

    Si j'utilise un mysql_fetch_row( ) j'aurai un tableau simple mais je vais avoir un problème avec les entetes de colonnes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     fputcsv($handle, array_keys($row), ';');
    Je ne sais pas si fputcsv( ) va aprécier, je vais essayer....
    Débusqueur de bug et chercheur en améliorations

  4. #4
    Membre actif
    Homme Profil pro
    électronicien
    Inscrit en
    Octobre 2006
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : électronicien
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 225
    Points : 236
    Points
    236
    Par défaut
    J'ai modifié mon script car n'étant pas familiarisé avec les tableaux associatifs j'ai fait quelques transformations: Ca bloque toujours (fige) sans raison.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
      $DBexport= mysql_query($sql);
        if(!$DBexport){ jsalert("Erreur mysql: ".  mysql_error()); return false; }
    
        $handle = fopen(EXPORT_CSV, 'w');
        if(!$handle){ jsalert( "le fichier ".EXPORT_CSV." n\'a pas été créé: "); return false; }
    
        $title  = mysql_field_array($DBexport);
        $row    = mysql_fetch_row($DBexport);
        if(!$row){ jsalert( "le fichier Mysql ne peut pas être lu ou est vide"); return false; }
    
        for($i=0;$i< mysql_num_fields($DBexport);$i++)  // fielf is numeric
            if(mysql_field_type($DBexport,$i)== 'int'||mysql_field_type($DBexport,$i)== 'float'||mysql_field_type($DBexport,$i)== 'tinyint'||
               mysql_field_type($DBexport,$i)== 'decimal')
                   $row[$i]= numberformat($row[$i],2,',','');
    
    
        fputcsv($handle, $title, ';');   // liste des titres de colonne
    
        do
        {
        	fputcsv($handle, $row, ';');            // on commence à remplir le tableau
        }
    
        while($row = mysql_fetch_assoc($DBexport));
        fputcsv($handle, $row, ';');                // on fini le remplissage du tableau
    La ligne en gras me fait toujours problème
    Débusqueur de bug et chercheur en améliorations

  5. #5
    Membre actif
    Homme Profil pro
    électronicien
    Inscrit en
    Octobre 2006
    Messages
    225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : électronicien
    Secteur : Bâtiment

    Informations forums :
    Inscription : Octobre 2006
    Messages : 225
    Points : 236
    Points
    236
    Par défaut
    Ca y est j'ai trouvé. numberformat( ) est bloquant
    J'ai remplacé par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $row[$i]= str_replace('.',',',$row[$i]);
    et ça fonctionne.
    C'est curieux, je ne comprends pas pourquoi mais le résultat est là.
    Débusqueur de bug et chercheur en améliorations

  6. #6
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    je pense qu'il faut vérifier que $row[$i] n'est pas vide ou NULL.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
        for($i=0;$i< mysql_num_fields($DBexport);$i++)
    		if(	$row[$i]!='' &&	$row[$i]!=NULL && 
    			in_array( mysql_field_type($DBexport,$i), array('int','float','tinyint','decimal') )
    			)
    		{ $row[$i]= numberformat($row[$i],2,',',''); }
    A tester...

Discussions similaires

  1. renommer des fichiers avec 4 décimales sous dos
    Par gundorf dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 17/06/2012, 10h33
  2. Réponses: 6
    Dernier message: 29/11/2006, 11h56
  3. Réponses: 1
    Dernier message: 31/10/2006, 15h06
  4. Export de base avec des tables liées
    Par Yali dans le forum Administration
    Réponses: 6
    Dernier message: 31/03/2006, 10h31
  5. Requete avec des décimales
    Par Sandrine75 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 27/06/2003, 10h18

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo