Précédent   Forum des professionnels en informatique > PHP > Langage > Fichiers
Fichiers Forum d'entraide sur les fichiers avec PHP. Avant de poster -> FAQ fichiers et Sources fichiers
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 19/06/2007, 15h25   #1
Invité de passage
 
Inscription : avril 2007
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 17
Points : 4
Points : 4
Par défaut [CSV] str_replace et fichier CSV

Bonjour,

Voici mon problème. Je lis les valeurs d'un fichier CSV afin de les insérer dans une table MySQL. Le 3ème champ de chaque ligne correspond au solde du client, c'est un flottant. Le soucis est que les valeurs ne respectent pas le format de la base de données. Exemple : 3 427,33. Il faut donc remplacer la virgule par un point et ôter l'espace. J'ai donc écrit le code suivant
Code :
1
2
3
4
5
6
 
$solde_alpha=$ligne[2]; //$ligne[2] est la variable qui contient le champ du CSV
$solde_alpha=str_replace(' ','',$solde_alpha);
echo $ligne[2]." = ".$solde_alpha." = ";
$solde_alpha=str_replace(',','.',$solde_alpha);
echo $solde_alpha."<br/>";
Mais le résultat donne ceci :
1 328,24 = 1 328,24 = 1 328.24
La virgule est bien remplacée par un point, mais l'espace ne disparaît pas. En revanche, l'espace disparaît si je donne une valeur en "dur" à $solde_alpha.
Code :
$solde_alpha="1 328,24";
A quoi est-ce dû ? Est-ce que ça peut être un problème d'encodage ?

PS : j'espère que je ne me suis pas trompé de section.
palmier est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/06/2007, 15h28   #2
Expert Confirmé
 
Avatar de trotters213
 
Inscription : janvier 2005
Messages : 2 572
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gard (Languedoc Roussillon)

Informations forums :
Inscription : janvier 2005
Messages : 2 572
Points : 2 605
Points : 2 605

La fonction number_format est faite pour ça
__________________
Pensez au tag
Les règles du Forum

Dev. Web : FAQ (X)HTML/CSS | Tutos (X)HTML | Tutos CSS

PHP : FAQ PHP | Tutos PHP | Benchmark PHP 5

SQL : Cours SQL
trotters213 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/06/2007, 15h38   #3
Invité de passage
 
Inscription : avril 2007
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2007
Messages : 17
Points : 4
Points : 4
Merci de ton aide, malheureusement, j'ai essayé ça :
Code :
1
2
$solde=number_format($ligne[2], 2, '.', '');
echo $ligne[2]." = ".$solde."<br/>";
Et le résultat a donné :
1 328,24 = 1.00
palmier est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 22h18.


 
 
 
 
Partenaires

Hébergement Web