Thanks! Thats about what I'm doing right now. function parse_prim_states($in) { preg_match('@prim_states[\s]*\((?<number>[0-9\s]*)@' ,$in , $matches); $this->num_prim_states = (int)$matches['number']; preg_match_all('@prim_state[\s]*\((?<flag1>[a-fA-F0-9\s]*)tex_idxs[\s]*\((?< texidx>[0-9\s]*)\)(?<flag2>[0-9\s]*)\)@' ,$in , $matches); for($i=0;$i<$this->num_prim_states;$i++) { $this->add_prim_state($matches['flag1'][$i],$matches['flag2'][$i],$matches[' texid'][$i]); } unset($matches); return true; } Regards -----Original Message----- From: Shawn McKenzie [mailto:nospam@xxxxxxxxxxxxx] Sent: Wednesday, September 09, 2009 7:57 PM To: Jan Reiter Cc: php-general@xxxxxxxxxxxxx Subject: Re: preg_match() Jan Reiter wrote: > Good Afternoon. > > > > This shouldn't be too complicated, but I can't come up with a solution for > the problem right now. It's about RegEx in PHP (5.2) > > > > Is there a way to capture ALL sub elements of an expression like > preg_match('@a(?[0-9])*b@' ,"a2345678b" , $matches); ?? > > This would produce (below) whereas I'd like to get all the elements (2-8) as > an array entry each . ([1]=>2, [2]=>3 .) > AFAIK, you would need to know how many digits are there and use that many capture groups (), because you only have one capture group which will be overwritten each iteration. An alternative for your simple example above would be to do: preg_match('@a([0-9]+)b@' ,"a2345678b" , $matches); --then-- print_r(str_split($matches[1])); To do this multiple times in a large string you would need: preg_match_all('@a([0-9]+)b@' ,"a2345678b" , $matches); foreach($matches[1] as $match) { print_r(str_split($match)); } -- Thanks! -Shawn http://www.spidean.com -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php Eingehende eMail ist virenfrei. Von AVG überprüft - www.avg.de Version: 8.5.409 / Virendatenbank: 270.13.71/2336 - Ausgabedatum: 09/09/09 06:53:00 -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php