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 20/01/2012, 16h28   #1
Invité de passage
 
Inscription : avril 2010
Messages : 8
Détails du profil
Informations forums :
Inscription : avril 2010
Messages : 8
Points : 1
Points : 1
Par défaut Expression régulière en PHP

Bonjour,

Je cherche un peu d'aide concernant une expression régulière.
Après avoir fait un print_r de ma variable $searchParams j'obtiens le résultat ci-dessous :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Array
(
    [hasValue] => 1
    [where] => Array
        (
            [0] => Array
                (
                    [0] => ((r.state LIKE '%6%') OR (r.state='6'))
                    [1] => ((r.school LIKE '%7%') OR (r.school='7'))
                )
 
            [1] => Array
                (
                )
 
        )
)
Je souhaiterais à partir d'un expression régulière obtenir le motif suivant sachant que les chiffres ne sont pas obligatoirement 6 et 7, l'expression régulière devrait ressembler à ca j'imagine (ereg_replace("r.state LIKE '%6%') OR ","",$searchParams)) mais ça ne marche pas:

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Array
(
    [hasValue] => 1
    [where] => Array
        (
            [0] => Array
                (
                    [0] => (r.state='6')
                    [1] => (r.school='7')
                )

            [1] => Array
                (
                )

        )
)
Merci d'avance :-)
david64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 20/01/2012, 17h17   #2
Membre Expert
 
Avatar de ska_root
 
Homme
Développeur informatique
Inscription : août 2005
Messages : 1 179
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 42
Localisation : France

Informations professionnelles :
Activité : Développeur informatique
Secteur : Service public

Informations forums :
Inscription : août 2005
Messages : 1 179
Points : 1 580
Points : 1 580
Bonjour,

j'ai pas tout compris...

tu veux un truc comme ça ? :

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
<?php
$arValues= array (
    'hasValue' => 1,
    'where' => array(
            array(
               "((r.state LIKE '%6%') OR (r.state='6'))",
               "((r.school LIKE '%7%') OR (r.school='7'))",
            ),
            array()
     )
);
 
$arRes= $arValues;
$arRes['where'] = array();
$pattern = '#(.*)OR(.*)\)#i';
 
if(isset($arValues['where'])) {
   foreach($arValues['where'] as $ar) {
      if(count($ar)) {
         foreach($ar as $criteria) {
            preg_match($pattern, $criteria, $matches);
            if(count($matches) == 3) $arRes['where'][]= $matches[2];
         }
      }
   }
}
 
echo "<h3>avant : </h3><pre>";
print_r($arValues);
echo "</pre><hr />";
 
echo "<h3>apres : </h3><pre>";
print_r($arRes);
echo "</pre><hr />";
?>
Images attachées
Type de fichier : jpg resultat.JPG (23,2 Ko, 4 affichages)
__________________
http://cdemarche.developpez.com/

Tu as la réponse à ta question ? N'oublies pas le petit en bas à gauche de ton message...
ska_root est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 20/01/2012, 17h31   #3
Membre éclairé
 
Avatar de Nowwis
 
Homme
Développeur Web
Inscription : juin 2009
Messages : 363
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 21
Localisation : France

Informations professionnelles :
Activité : Développeur Web

Informations forums :
Inscription : juin 2009
Messages : 363
Points : 365
Points : 365
Et pour compléter ska_root, pour avoir n'importe quel chiffre, autant bien 6 et 7 que 8 et 9... :

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
$arValues= array (
    'hasValue' => 1,
    'where' => array(
            array(
               "((r.state LIKE '%9%') OR (r.state='6'))",
               "((r.school LIKE '%8%') OR (r.school='7'))",
            ),
            array()
     )
);
 
$arRes= $arValues;
$arRes['where'] = array();
$pattern = '#(.*)([0-9]*)(.*)OR(.*)\)#i';
 
if(isset($arValues['where'])) {
   foreach($arValues['where'] as $ar) {
      if(count($ar)) {
         foreach($ar as $criteria) {
            preg_match($pattern, $criteria, $matches);
            if(count($matches) == 5) $arRes['where'][]= $matches[1].$matches[2].$matches[3];
         }
      }
   }
}
 
echo "<h3>avant : </h3><pre>";
print_r($arValues);
echo "</pre><hr />";
 
echo "<h3>apres : </h3><pre>";
print_r($arRes);
echo "</pre><hr />";
Enjoy
Nowwis est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 20/01/2012, 19h18   #4
Invité de passage
 
Inscription : avril 2010
Messages : 8
Détails du profil
Informations forums :
Inscription : avril 2010
Messages : 8
Points : 1
Points : 1
Par défaut Merci

Merci beacucoup, j'ai déja commencé à l'adapter à mon code en modifiant une petite chose et ça marche plutot bien :

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
$arRes= $searchParams;
$arRes['where'] = array();
$arRes['where'][0] = array();
$pattern = '#(.*)OR(.*)\)#i';
 
if(isset($searchParams['where'])) {
$key=0;
   foreach($searchParams['where'] as $ar) {
;
   echo $key;
      if(count($ar)) {
         foreach($ar as $criteria) {
 
            preg_match($pattern, $criteria, $matches);
 
            if(count($matches) == 3){ $arRes['where'][0][$key] = $matches[2];$arRes['where'][1]= array(); $key+=1;}
         }
      }
   }
}
 
echo "<h3>avant : </h3><pre>";
print_r($searchParams);
echo "</pre><hr />";
 
echo "<h3>apres : </h3><pre>";
print_r($arRes);
echo "</pre><hr />";
Le dernier problème est que ça me renvoie bien :

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
avant :
 
Array
(
    [hasValue] => 1
    [where] => Array
        (
            [0] => Array
                (
                    [0] => ((r.title LIKE '%ma%') OR (r.title='ma'))
                    [1] => ((r.city LIKE '%fsdfsd%') OR (r.city='fsdfsd'))
                    [2] => ((r.state LIKE '%17%') OR (r.state='17'))
                    [3] => ((r.school LIKE '%12%') OR (r.school='12'))
                )
 
            [1] => Array
                (
                )
 
        )
 
    [link_search] => index.php?option=com_jobs&task=search_resume&Itemid=8&user_id=87&db_title=ma&db_city=fsdfsd&db_state=17&db_school=12
)
 
apres :
 
Array
(
    [hasValue] => 1
    [where] => Array
        (
            [0] => Array
                (
                    [0] =>  (r.title='ma')
                    [1] =>  (r.city='fsdfsd')
                    [2] =>  (r.state='17')
                    [3] =>  (r.school='12')
                )
 
            [1] => Array
                (
                )
 
        )
 
    [link_search] => index.php?option=com_jobs&task=search_resume&Itemid=8&user_id=87&db_title=ma&db_city=fsdfsd&db_state=17&db_school=12
)
J'aimerais que ça m'enlève le LIKE que pour school et state mais je n'arrive pas à trouver comment faire ma condition sur r.state et r.school.

J'espère être clair!

Merci encore.
david64 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 03h01.


 
 
 
 
Partenaires

Hébergement Web