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 09/05/2006, 14h54   #1
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
Par défaut Expression régulière

hello tous le monde,
j'ai des soucis d'expression régulière.
Alors mes problèmes sont:
Quand je mets :
Code :
1
2
 
preg_match_all("/\trowd/",$texte,$test);
cela ne me retourne rien alors que dans mon texte j'ai : cellx9639\row }\trowd \trgaph70\trleft-
Je developpe un peu j'ai un document rtf, j'ai identifié comment rajouter une ligne dans un tableau, le problème c'est que à l'heure actuelle j'ai truc comme :
$newLine = '\\trowd \\trgaph70\\trleft-70\\trbrdrt\\brdrs\\brdrw5 \\trbrdrl \\brdrs\\brdrw5 \\trbrdrb\\brdrs\\brdrw5 \\trbrdrr\\brdrs\\brdrw5 \\trbrdrh\\brdrs\\brdrw5 \\trbrdrv\\brdrs\\brdrw5 \\trftsWidth1\\trpaddl70\\trpaddr70\\trpaddfl3\\trpaddfr3 \\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl\\brdrs\\brdrw45 \\clbrdrb\\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw5 \\cltxlrtb\\clftsWidth3\\clwWidth2055 \\cellx1985\\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl\\brdrs\\brdrw5 \\clbrdrb\\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw5 \\cltxlrtb\\clftsWidth3\\clwWidth5528 \\cellx7513\\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl\\brdrs\\brdrw5 \\clbrdrb \\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw45 \\cltxlrtb\\clftsWidth3\\clwWidth2126 \\cellx9639\\pard\\plain \\s50\\qj \\li0\\ri0\\widctlpar\\intbl\\aspalpha\\aspnum\\faauto\\adjustright\\rin0\\lin0 \\f1\\fs20\\lang1033\\langfe1036\\cgrid\\langnp1033\\langfenp1036 '.$string_replace.'\\pard\\plain \\ql \\li0\\ri0\\widctlpar\\intbl\\aspalpha\\aspnum\\faauto\\adjustright\\rin0\\lin0 \\f1\\fs22\\lang1036\\langfe1036\\cgrid\\langnp1036\\langfenp1036 {\\lang1033\\langfe1036\\langnp1033 \\trowd \\trgaph70\\trleft-70\\trbrdrt \\brdrs\\brdrw5 \\trbrdrl\\brdrs\\brdrw5 \\trbrdrb\\brdrs\\brdrw5 \\trbrdrr\\brdrs\\brdrw5 \\trbrdrh\\brdrs\\brdrw5 \\trbrdrv\\brdrs\\brdrw5 \\trftsWidth1\\trpaddl70\\trpaddr70\\trpaddfl3\\trpaddfr3 \\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl\\brdrs\\brdrw45 \\clbrdrb\\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw5 \\cltxlrtb\\clftsWidth3\\clwWidth2055 \\cellx1985\\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl\\brdrs\\brdrw5 \\clbrdrb\\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw5 \\cltxlrtb\\clftsWidth3\\clwWidth5528 \\cellx7513\\clvertalt\\clbrdrt\\brdrs\\brdrw5 \\clbrdrl \\brdrs\\brdrw5 \\clbrdrb\\brdrs\\brdrw10 \\clbrdrr\\brdrs\\brdrw45 \\cltxlrtb\\clftsWidth3\\clwWidth2126 \\cellx9639\\row }';
a rajouter donc c'est du brut.
Je voudrais pouvoir récupere un ligne que je copierai avec mes valeurs.

J'avais pris comme pattern : ^(\\trowd)(.*)(DOC2)(.*)(REF2)(.*)(VERS2)(.*)(\\row })$ mais ca ne marche pas.
Deplus quend je fais des test simples sur doc2, par exemple, si je mets ^avant je n'obtiens rien et si je l'enleve ca marche .

comme vous l'avais peut etre vu j'ai juste besoin de dire que je veux un string qui commence par \trowd qui contient DOC2,VERS2,et REF2 et qui fini par \row }
mais la je bloque
Si quequ'un a une idée elle sera la bien venu
Merci d'avance
tit_oune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h05   #2
Membre Expert
 
Homme
Inscription : janvier 2004
Messages : 1 238
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Secteur : Finance

Informations forums :
Inscription : janvier 2004
Messages : 1 238
Points : 1 421
Points : 1 421
normal, \t est le symbole de la tabulation, donc si tu veux matcher le caractere \ suivi de t, il te faut indiquer \\t

Attention toutefois puisque cela risque de marcher uniquement si tu entoure ta chaine de '' (apostrophes) et non de "" (quote), car si tu utilise des quotes, la chaine sera une premiere fois evaluée en php avant d'etre passé a preg_* ce qui fait que l'un des \ sera supprimé.
Si tu veux utiliser "", il te faut donc marquer : \\\\t

Compliqué ? mais non ;o))
__________________
PHP :
Regle n°1 : mysql_query(...), mysql_connect(...) et mysq_select_db(...) doivent EN DEBUG etre suivies de or die(mysql_error()); (mais jamais en production)
Regle n°2 : Mieux encore : mysql_query($requete) or die("$requete<br/>".mysql_error());
Regle n°3 : echo '<pre>';var_dump($var);echo '</pre>'; affiche le contenu et le type d'une variable.
Publiez vos textes de fantasy et de science-fiction sur http://www.cercledefaeries.com/concours/
Fladnag est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h12   #3
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
pour le \\ je m'en doutais et donc j'avais deja testé, je viens de tester
Code :
1
2
 
preg_match_all("/\\\\trowd/",$texte,$test)
et en effet ca marche.
Mais je viens de tester
Code :
1
2
 
preg_match_all("/^\\\\trowd(.*)\\\\row[ ]}$/",$texte,$test)
et ca ne marche pas.
Pour l'expression reguliere que je decris est :
commence par \trowd suivie de ce que je veux et fini par \row }. mais a priori non
tit_oune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h20   #4
Membre chevronné
 
Avatar de stunti
 
Inscription : mai 2006
Messages : 521
Détails du profil
Informations personnelles :
Âge : 33

Informations forums :
Inscription : mai 2006
Messages : 521
Points : 602
Points : 602
si c'est sur plusieur ligne il faut mettre me modification m

Code :
preg_match_all("/^\\\\trowd(.*)\\\\row[ ]}$/m",$texte,$test)
stunti est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h24   #5
Membre Expert
 
Homme
Inscription : janvier 2004
Messages : 1 238
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Secteur : Finance

Informations forums :
Inscription : janvier 2004
Messages : 1 238
Points : 1 421
Points : 1 421
Tu essaye de matcher la chaine : "\\row }"
avec "\\\\row[ ]}" ?

Pourquoi des crochets ?

Si ton texte est sur plusieurs lignes, il faut que tu ajoute l'option "s" a ton masque, comme ca :
"/..../s"
pour que le (.*) prenne aussi les caracteres \r et \n
(http://fr2.php.net/manual/fr/reference.pcre.pattern.modifiers.php)

essaye ensuite sans ^ et $ d'abord :

Code :
 preg_match_all("/\\\\trowd(.*)\\\\row/s",$texte,$test)
pour voir si il te trouve quelque chose, puis ajoute progressivement l'espace, le }, le ^ au debut et enfin $ a la fin en voyant a quel caractere il bloque.

Edit : oui, "m" aussi en effet ;o)
__________________
PHP :
Regle n°1 : mysql_query(...), mysql_connect(...) et mysq_select_db(...) doivent EN DEBUG etre suivies de or die(mysql_error()); (mais jamais en production)
Regle n°2 : Mieux encore : mysql_query($requete) or die("$requete<br/>".mysql_error());
Regle n°3 : echo '<pre>';var_dump($var);echo '</pre>'; affiche le contenu et le type d'une variable.
Publiez vos textes de fantasy et de science-fiction sur http://www.cercledefaeries.com/concours/
Fladnag est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h27   #6
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
en effet je pense que ca dois jouer le fait que c'est sur plusieur ligne mais je viens de tester ce que stunti ma donner et ca ne marche pas
tit_oune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h31   #7
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
Oui en effet c'était bien ca Fladnag.
Maintenant j'ai un autre soucis je voudrais recuperer la plus courte chaine de caractere qui correspond a mon expression regulière.
tit_oune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h39   #8
Membre Expert
 
Homme
Inscription : janvier 2004
Messages : 1 238
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Secteur : Finance

Informations forums :
Inscription : janvier 2004
Messages : 1 238
Points : 1 421
Points : 1 421
Pour la plus courte chaine il faut utiliser le modificateur "U" ;o)
__________________
PHP :
Regle n°1 : mysql_query(...), mysql_connect(...) et mysq_select_db(...) doivent EN DEBUG etre suivies de or die(mysql_error()); (mais jamais en production)
Regle n°2 : Mieux encore : mysql_query($requete) or die("$requete<br/>".mysql_error());
Regle n°3 : echo '<pre>';var_dump($var);echo '</pre>'; affiche le contenu et le type d'une variable.
Publiez vos textes de fantasy et de science-fiction sur http://www.cercledefaeries.com/concours/
Fladnag est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 15h52   #9
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
oui ca marche mais quand je mets :
Code :
1
2
 
preg_match_all("/\\\\trowd(.*)REF2(.*)\\\\row/sU",$texte,$test)
ou lieu de
Code :
1
2
 
preg_match_all("/\\\\trowd(.*)\\\\row/sU",$texte,$test)
parce que en faite je voudrais que seule la ligne contenant REF2 soit prise bah la je n'ai plus rien
tit_oune est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 16h05   #10
Membre Expert
 
Homme
Inscription : janvier 2004
Messages : 1 238
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Secteur : Finance

Informations forums :
Inscription : janvier 2004
Messages : 1 238
Points : 1 421
Points : 1 421
dans le morceau de fichier RTF que tu as copier/collé au dessus, il n'y a pas de REF2, tu est sur que ton $texte en contient bien et au bon endroit ?
__________________
PHP :
Regle n°1 : mysql_query(...), mysql_connect(...) et mysq_select_db(...) doivent EN DEBUG etre suivies de or die(mysql_error()); (mais jamais en production)
Regle n°2 : Mieux encore : mysql_query($requete) or die("$requete<br/>".mysql_error());
Regle n°3 : echo '<pre>';var_dump($var);echo '</pre>'; affiche le contenu et le type d'une variable.
Publiez vos textes de fantasy et de science-fiction sur http://www.cercledefaeries.com/concours/
Fladnag est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/05/2006, 16h07   #11
Nouveau Membre du Club
 
Inscription : mars 2006
Messages : 111
Détails du profil
Informations forums :
Inscription : mars 2006
Messages : 111
Points : 30
Points : 30
c bon ca marche j'ai mis :
Code :
1
2
 
preg_match_all("/\\\\trowd(.*)CUST_REF[0-9]\\\\cell(.*)\\\\row/sU",$texte,$test)
Merci à tous de votre aide.
tit_oune 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 12h03.


 
 
 
 
Partenaires

Hébergement Web