Précédent   Forum des professionnels en informatique > PHP > Langage > Regex
Regex Forum d'entraide sur les expressions rationnelles PHP. Avant de poster -> FAQ regex, Cours de regex et Sources de regex
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 01/08/2007, 16h01   #1
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
Par défaut preg_match : format de données

Bonjour à tous ,

j'aimerais vérifier qu'une information est saisie sous la forme:
x°y'z" et j'ai utiliser ceci:
preg_match (/(\d+)°(\d+)\'(\d+)\"/, $latitude), mais ça signale une erreur de syntaxe:
Parse error: parse error, unexpected '/', expecting ')'

une idée. merçi d'avance pour votre aide
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/08/2007, 16h06   #2
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
Citation:
Envoyé par guestCam
Bonjour à tous ,

j'aimerais vérifier qu'une information est saisie sous la forme:
x°y'z" et j'ai utiliser ceci:
preg_match (/(\d+)°(\d+)\'(\d+)\"/, $latitude), mais ça signale une erreur de syntaxe:
Parse error: parse error, unexpected '/', expecting ')'

une idée. merçi d'avance pour votre aide
Code :
preg_match ("/(\d+)°(\d+)\'(\d+)\"/", $latitude)
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/08/2007, 16h20   #3
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
je viens d'ajouter les 2 guillemets comme tu m'as dit, donc j'ai

Code :
preg_match ("/(\d+)°(\d+)\'(\d+)\"/", $latitude)
,

l'erreur actuel est:

Parse error: parse error, unexpected '\"', expecting ',' or ';'

Là je ne vois pas l'erreur, une idée?
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/08/2007, 16h43   #4
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
La syntaxe ça passe, mais quand je saisie les données correctes, la vérification est fausse.
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/08/2007, 16h56   #5
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
Quand je saisie une bonne donnée et que j'essaie d'afficher à l'écran ça me donne par exemple ceci avec un echo :
2°22\'3\" alors que j'ai saisie 2°22'3".
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/08/2007, 18h18   #6
En attente de confirmation mail
 
Inscription : juin 2002
Messages : 6 164
Détails du profil
Informations forums :
Inscription : juin 2002
Messages : 6 164
Points : 6 404
Points : 6 404
L'apostrophe figurant dans le masque n'a pas besoin d'être échappée a priori.

Si vos données proviennent d'un formulaire, les antislashs supplémentaires sont surement le fruit de la fonctionnalité magic_quotes_gpc auquel cas la fonction stripslashes sera nécessaire avant sur ces mêmes données.
julp est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 09h53   #7
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
salut julp,
la fonctionne stripslashes me permet d'afficher la chaine correctement(merçi pour l'info).
mon problème maintenant est que preg_match retourne faux même quand je saisie une chaine correcte(genre 45°125'12").
Est-ce que mon pattern
Code :
"/(\d+)°(\d+)\'(\d+)\"/"
aurait des problèmes?
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 10h14   #8
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
Citation:
Envoyé par guestCam
salut julp,
la fonctionne stripslashes me permet d'afficher la chaine correctement(merçi pour l'info).
mon problème maintenant est que preg_match retourne faux même quand je saisie une chaine correcte(genre 45°125'12").
Est-ce que mon pattern
Code :
"/(\d+)°(\d+)\'(\d+)\"/"
aurait des problèmes?
Comme l'a dit julp il faut surement retirer le backslash avant la quote simple
Code :
"/(\d+)°(\d+)'(\d+)\"/"
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 10h22   #9
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
j'ai enlevé l'anti-slash sur l'apostrophe, mais jusque là lorsque je saisie 23°45'356", ça me renvoie toujours false.
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 10h32   #10
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
Citation:
Envoyé par guestCam
j'ai enlevé l'anti-slash sur l'apostrophe, mais jusque là lorsque je saisie 23°45'356", ça me renvoie toujours false.
Moi ce code:
Code :
1
2
3
4
<?php
$latitude = "23°45'356\"";
var_dump(preg_match ("/([0-9]+)°([0-9]+)'([0-9]+)\"/", $latitude));
?>
me renvoie bien 1
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 10h52   #11
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
si j'initialise ma chaine avec une constante comme tu dis, ça fonctionne, mais cette chaine, je dois la récupérer avec $latitude = $_POST[$field],
et c'est là où ça ne fonctionne pas quand j'appelle preg_match sur $latitude.

En appelant la fonctionne stripslashes et en faisant echo j'ai par exemple 25°45'123". je sèche
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 10h57   #12
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
remplaces "echo" par var_dump($_POST[$field]) pour bien voir le contenu de ta chaine (y compris les espaces, les caractères html etc).
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 11h05   #13
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
j'obtiens ceci en faisant var_dump($_POST[$field]):

string(13) "25°45\'123\""
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 11h16   #14
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
Citation:
Envoyé par guestCam
j'obtiens ceci en faisant var_dump($_POST[$field]):

string(13) "25°45\'123\""
voila donc tu obtiens un \ avant la quote et avant la double quote ! il faut donc que tu enlèves ces backslahes superflus avant d'utiliser preg_match:
Code :
$latitude = stripslashes($_POST[$field]);
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 11h26   #15
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
c'est ce que j'avais fait comme je t'expliquais:
puisque j'avais dit que j'obtenais 25°45'123" en appliquant stripslahes; ce qui est différent de la constante 25°45'123\"(qui "matches" bien le pattern).

donc stripslahes($_POST[$field]) me renvoie 25°45'123" qui ne "matches" pas le pattern.
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 11h37   #16
En attente de confirmation mail
 
Inscription : juin 2002
Messages : 6 164
Détails du profil
Informations forums :
Inscription : juin 2002
Messages : 6 164
Points : 6 404
Points : 6 404
A ce stade, donnez nous votre code (un code minimal) et nous testerons. Ce sera plus simple je pense.
julp est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 11h44   #17
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
Quand j'affiche le code source via le browser j'obtiens:

longitude = 25°45'123"

Je pense que c'est le caractère spécial qui pose problème.
comment le retirer?
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 12h06   #18
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
voiçi une partie de mon code, regarder juste $local_longitude.


Code :
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
if($saveMote){
  #save the new mote information into the database.
 
  if(!$conn){
    die("Could not connect to database server!<br />");
  } else {
    $query = "SELECT * FROM $table WHERE miid=$miid";
    $result = pg_query($query);
 
    $meta = pg_meta_data($conn, $table);
 
    $query = "UPDATE $table SET";
    if (is_array($meta)){
      // for every field
      $count = 0;
      foreach(array_keys($meta) as $field){
	echo "$field,\n ";
 
	//take the longitude_dms and latitude_dms for check purpose before querying(awal_start)
 
	if (strcmp($field,"longitude_dms")==0){
	  $local_longitude=stripslashes($_POST[$field]);
	  var_dump($_POST[$field]);
	  //echo "local_longitude = ".stripslashes($local_longitude);//add
	  echo " ".strcmp($field,"longitude_dms")." ";//add
	 }
	else if (strcmp($field,"longitude_dms")==0){
	  $local_latitude = $_POST[$field];
	  echo " ".strcmp($field,"latitude_dms")." ";//add
	}
 
	//end take (awal_end)
 
	$type = $meta[$field]["type"];
	if(($type=="int4") || ($type=="numeric")){
	  if ($_POST[$field]){
	    if($count != 0){
	      $query .= ",";
	    }
	    $query .= " $field=".$_POST[$field];
 
	  }
	} else if($type == "varchar"){
	  if($count != 0){
	    $query .= ",";
	  }
	  $query .= " $field='".$_POST[$field]."'";
	} else if($type == "timestamp") {
	  if($count != 0){
	    $query .= ",";
	  }
	  if($_POST[$field] != ""){
	    $query .= " $field='".$_POST[$field]."'";
	  } else {
	    $query .= " $field=now()";
	  }
	} 
	$count += 1;
      }
    }
 
 
 
    $query .= " WHERE miid=$miid";
  echo $query;
  echo "local longitude = ".$local_longitude;
 
  //verify the pattern matching before querying (awal_start)
 
  #$pattern ="/(\d+)°(\d+)\'(\d+)\"/"; 
 
  //$local_longitude = stripslashes($local_longitude);//remove anti-
  //$local_longitude = "25°33'23\"";
  //$local_longitude = stripslashes($local_longitude);
 
 
  echo "valeur de retour de preg_match : ".preg_match("/([0-9]+)°([0-9]+)'([0-9]+)\"/",$local_longitude);
 
  if (preg_match("/([0-9]+)°([0-9]+)'([0-9]+)\"/",$local_longitude)){ //correct format was entered
    $res = pg_query($query);
 
    // show the new mote data
    showmotes($table, $conn, $clusterid);
  }
  else
    {
      echo "latitude and longitude must have the following format x°y'z";
    }
il ne fonctionne à cause de local_longitude qui contient les données au mauvais format.
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/08/2007, 14h52   #19
Membre à l'essai
 
Inscription : octobre 2006
Messages : 127
Détails du profil
Informations forums :
Inscription : octobre 2006
Messages : 127
Points : 23
Points : 23
j'ai du utilisé la fonction utf8_decode sur ma variable pour résoudre le problème.
Merçi pour vos interventions qui m'ont bcp aidé
guestCam est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 04h06.


 
 
 
 
Partenaires

Hébergement Web