Solved

Java regex for nested pattern

Posted on 2004-04-29
11
921 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
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
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
 
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

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
tomcat startup error 5 132
maven disable workspace resolution 1 37
Why doesn't this text field show up on my Applet frame? 2 26
spring maven example issues 3 37
For beginner Java programmers or at least those new to the Eclipse IDE, the following tutorial will show some (four) ways in which you can import your Java projects to your Eclipse workbench. Introduction While learning Java can be done with…
In this post we will learn how to make Android Gesture Tutorial and give different functionality whenever a user Touch or Scroll android screen.
Viewers will learn one way to get user input in Java. Introduce the Scanner object: Declare the variable that stores the user input: An example prompting the user for input: Methods you need to invoke in order to properly get  user input:
This theoretical tutorial explains exceptions, reasons for exceptions, different categories of exception and exception hierarchy.

679 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