Vlastní reference – Regulární výrazy – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Vlastní reference – Regulární výrazy – Fórum – Programujte.comVlastní reference – Regulární výrazy – Fórum – Programujte.com

 

Hledá se programátor! Plat 1 800 € + bonusy (firma Boxmol.com)
Lukáš
~ Anonymní uživatel
275 příspěvků
9. 9. 2014   #1
-
0
-

Zdravím, mám dlouhý regex a ten se dělí na více částí a po porovnání s textem potřebuji vědět která část výrazu se s textem shoduje.
Příklad: 

<?php
  $text = 'Ahoj svete! No nic, ja jdu, tak nazdar!';
  $regex = '/(?:ahoj|cau|nazdar)/i';
  preg_match_all($regex, $text, $matches);
  print_r($matches);
?>

Vrací: 

Array
(
    [0] => Array
        (
            [0] => Ahoj
            [1] => nazdar
        )

)

Ale já potřebuji, abych měl ve výsledcích nějakou identifikaci té části výrazu, se kterým se ten který výsledek shoduje. Tzn. třeba něco jako:

  $text = 'Ahoj svete! No nic, ja jdu, tak nazdar!';
  $regex = '/(?:(?#454)ahoj|(?#455)cau|(?#456)nazdar)/i';
  preg_match_all($regex, $text, $matches);
  print_r($matches);

aby vrátilo:

Array
(
    [0] => Array
        (
            [0] => Array
                (
                    [0] => Ahoj
                    [1] => 454
                )
            [0] => Array
                (
                    [0] => nazdar
                    [1] => 456
                )
        )
)


... nebo tak něco :D Nenapadá vás nějaké řešení?

Nahlásit jako SPAM
IP: 212.4.134.–
Reklama
Reklama
Matěj Andrle+1
Grafoman
9. 9. 2014   #2
-
0
-

#1 Lukáš
O co přesně se snažíš?

Nahlásit jako SPAM
IP: 78.136.191.–
Lukáš
~ Anonymní uživatel
275 příspěvků
9. 9. 2014   #3
-
0
-

Jak to myslíš? O to, co popisuju :)

Nejde mi o to jak vyřešit můj případ - mohl bych to předelat a víc oddělených výrazů a měl bych po starostech, ale pak by byla doba běhu scriptu delší. Chci zachovat tento způsob (tedy pospojování více regexpů do jednoho a plošně ho použít na text), ale mít možnost zjistit jaká část regexpu našla které slovo.

Nahlásit jako SPAM
IP: 212.4.134.–
Flowy0
Věrný člen
9. 9. 2014   #4
-
0
-

rychlost kodu by sa neznizila resp by to nebolo nejak zasadne ... problem by bol ze by to vyzeralo vazne blbo ...

pozri si manual pre regex ... (?:exp) znamena skupinu ktora sa nezachytava (aktualne ti zachytava retazec ako celok) ... najdi si ako oznacit pomenovanu skupinu

ps: aspon v jave je (?:X) anonymna skupina ale predpokladam ze v php to bude to iste

btw asi budes mat rychlejsie vytvorit zoznam slov do array a kazde z nich vyhladat v texte cez iteraciu ... pri hladani jednotliveho slova sa to bude spravat pravdepodobne rychlejsie kedze sa tam da spravit par detailnych optimalizacii oproti regexu ktoreho rychlost nieje az taka dolezita

Nahlásit jako SPAM
IP: 95.103.149.–
https://github.com/Flowy
Lukáš
~ Anonymní uživatel
275 příspěvků
9. 9. 2014   #5
-
0
-

V reálu ale nehledám takto jednoduchá slova, ale složitější výrazy, takže ty regexpy tam mít bohužel musím. A kdyby jich bylo třeba 200, tak než to iterovat, tak mi přijde lepší použít jeden dlouhý regexp.
Jojo, (?: a (?# a další šméčka znám, ale to co jsem potřeboval jsem nenašel.

Ale teď koukám a testuju, že toto:

(?P<jmeno>ahoj)

je asi to co hledám. Pomohlo mi to slovo "pojmenovaná" (EN: named) a pak už jsem to našel. To jsem neznal - vyzkouším to a dám vědět. Zatím díky :)

Nahlásit jako SPAM
IP: 212.4.134.–
peter
~ Anonymní uživatel
2528 příspěvků
10. 9. 2014   #6
-
0
-
Nahlásit jako SPAM
IP: 2001:718:2601:1f7:a4c1:ce...–
Lukáš
~ Anonymní uživatel
275 příspěvků
10. 9. 2014   #7
-
0
-

Tak to:

(?P<jmeno>vyraz)

je přesně to co jsem hledal. Díky moc Flowy za kopanec :)

2peter: jn, tomu jsem se chtěl právě vyhnout ;)

OK, díky za rady a tento thread považuji za vyřešen! :)

Nahlásit jako SPAM
IP: 212.4.134.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 2 hosté

Podobná vlákna

Reference — založil Míša

SQL - reference — založil Ondra

Nulova reference? — založil Mutagen

Reference na int; — založil drobax

Reference ve 2d poli — založil Midnight

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032016 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý