Solved

Java regex for nested pattern

Posted on 2004-04-29
11
915 Views
Last Modified: 2008-03-06
Hello regex experts! Here is my riddle:

String input = "aaa${text1${text2}bbb}ccc${text3}";
String regex = "helpMeFindIt";
Pattern p = Pattern.compile(regex);
Matcher m = p.matcher(input);
while (m.find()){
   System.out.println(input.substring(m.start(), m.end()));            
}

Please help me find regex that results in the following output:
${text1${text2}bbb}
${text2}
${text3}

P.S. the closest I was able to get is "\\$\\{.+?\\}". Predictably, it provides a wrong answer.
0
Comment
Question by:javacube
  • 5
  • 3
  • 2
11 Comments
 

Author Comment

by:javacube
ID: 10956631
Thanks and good luck everyone!
0
 
LVL 92

Expert Comment

by:objects
ID: 10956666
i don't think you can achieve that with a single regex.
the second match will start at "ccc.."
0
 

Author Comment

by:javacube
ID: 10956943
> the second match will start at "ccc.."
with what regex?
0
 
LVL 92

Expert Comment

by:objects
ID: 10956984
with any regex that returns the desired pattern (${text1${text2}bbb}).
I think you need to use a second regex on the matched string, or something like that.
0
 

Author Comment

by:javacube
ID: 10957015
could you provide with ANY regex that results in the output starting at "ccc..."
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 15

Assisted Solution

by:ozymandias
ozymandias earned 125 total points
ID: 10957954
Here :

import java.util.regex.*;

public class regextest3{

      public static void main(String[] args){

            String input = "aaa${text1${text2}bbb}ccc${text3}";
            String regex = "[^\\$]*(.*(\\$\\{[^\\}]*\\})[^\\}]*\\}).*(\\$\\{.*\\})$";
            Pattern p = Pattern.compile(regex);
            Matcher m = p.matcher(input);

            if (m.matches()){
                  System.out.println(m.group(1));
                  System.out.println(m.group(2));
                  System.out.println(m.group(3));
            }else{
                  System.out.println("no match");
            }


      }

}
0
 

Author Comment

by:javacube
ID: 10962135
ok, this regex fails in finding the pattern. it matches the whole input string and prints out groups (stuff in brackets).  to test your solution: iterate with m.find, as in the original posting
0
 
LVL 15

Expert Comment

by:ozymandias
ID: 10962267
what do you mean? the output of the program I posted is exactly as described in your question. it matches the pattern and identifies the nested sub-patterns.
0
 

Author Comment

by:javacube
ID: 10963377
I checked your regex against my original posting: m.find() with your regex outputs "aaa${text1${text2}bbb}ccc${text3}". This is the only pattern found. It's different from the expected outcome. I believe this is because you mistake groups with pattern matches. They are not equal. The groups are not found - they are programmed with brakets. Groups are hardwired - for example, in your case, group print out results in the desired output if and only if the first group has a nested pattern and is followed by a group without a nested pattern. Just try to add a nested pattern to the second groups, and it breaks, or add a third group - it fails again.
0
 
LVL 92

Accepted Solution

by:
objects earned 125 total points
ID: 10964724
as i said above you cannot use a single regex to locate nested patterns, you instead need to use a second regex on the matched string.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

For customizing the look of your lightweight component and making it look opaque like it was made of plastic.  This tip assumes your component to be of rectangular shape and completely opaque.   (CODE)
This was posted to the Netbeans forum a Feb, 2010 and I also sent it to Verisign. Who didn't help much in my struggles to get my application signed. ------------------------- Start The idea here is to target your cell phones with the correct…
Viewers learn about the “while” loop and how to utilize it correctly in Java. Additionally, viewers begin exploring how to include conditional statements within a while loop and avoid an endless loop. Define While Loop: Basic Example: Explanatio…
The viewer will learn how to implement Singleton Design Pattern in Java.

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

24 Experts available now in Live!

Get 1:1 Help Now