Avatar billede danino Nybegynder
21. marts 2006 - 15:22 Der er 3 kommentarer og
1 løsning

regex spørgsmål (i php)

Er der nogen der kan hjælpe mig med følgende regex.

Jeg skal matche alt hvad der kan stå i en mysql_query(), hvor flere ting kan forekomme
mysql_query("SELECT * FROM table WHERE something=something") or die(mysql_error());
mysql_query("SELECT * FROM table WHERE something=something") or die(mysql_error() . "<br>In:<br>\n" . ("SELECT * FROM table WHERE something=something");
mysql_query($sql) or die(mysql_error());
mysql_query($sql) or die(mysql_error() . "<br>In:<br>\n" . $sql);
mysql_query("SELECT something FROM table WHERE " . $whereclause) or die...
osv...

jeg har selv forsøgt med følgende, uden det store held
<?php
$pattern = "/mysql_query\((.*)\)/i";
$replace = "\$db->query(\$1);";
preg_replace($pattern, $replace, $string);
?>

Det er nemlig meningen at det skal replaces med
$db->query(her skal der stå det samme som i den gamle query hvad enten det er en variabel eller noget tekst skrevet direkte)

Er der nogen der kan hjælpe med det?
Avatar billede jensgram Nybegynder
02. april 2006 - 11:42 #1
$pattern = "/\bmysql_query\((.*?)\)( or die\(.*\))?;\b/i";

Utestet, men virker måske...
Avatar billede jensgram Nybegynder
02. april 2006 - 11:47 #2
Nej, hvis man nu fjerner de to boundaries \b, så virker den vist...

http://www.fileformat.info/tool/regex.htm giver ihvertfald bonus (korrekt) på alle fem ovennævnte:

mysql_query("SELECT * FROM table WHERE something=something") or die(mysql_error());
-> "SELECT * FROM table WHERE something=something"

mysql_query("SELECT * FROM table WHERE something=something") or die(mysql_error() . "<br>In:<br>\n" . ("SELECT * FROM table WHERE something=something");
-> "SELECT * FROM table WHERE something=something"

mysql_query($sql) or die(mysql_error());
-> $sql

mysql_query($sql) or die(mysql_error() . "<br>In:<br>\n" . $sql);
-> $sql

mysql_query("SELECT something FROM table WHERE " . $whereclause) or die("...");
-> "SELECT something FROM table WHERE " . $whereclause
Avatar billede danino Nybegynder
02. april 2006 - 13:59 #3
Det virker sikkert... Læg du bare et svar, og få points... Jeg havde glemt jeg havde spørgsmålet åbnet... Havde fundet en anden løsning...
Avatar billede jensgram Nybegynder
02. april 2006 - 15:56 #4
Ok.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester