Solved

Need help with a couple of regex and replacement string

Posted on 2011-09-20
13
286 Views
Last Modified: 2012-08-13
1.      DisplayName:  I want to add a space after the comma for example: Doe,john  This should be Doe, John
2.      Telephone:  I want it formatted as “(323) 442-2455”, not as “+1 323 442 2455”

I need help with the regex for the above 2 and then the Replacement string for Regex.Replace method.  Thank you.

0
Comment
Question by:lapucca
  • 8
  • 5
13 Comments
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571341
1.
Find pattern:
,(?!\s)
and replace with
,
The comma on the previous line has a space after it. Note that the negative lookahead (?!\s) prevents a space being added if the comma already has a space after it.
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571350
2.
Find pattern "^\+\d\s?(\d{3})\s?(\d{3})\s?(\d{4})"
And replace with:
($1) $2-$3
0
 
LVL 35

Accepted Solution

by:
Terry Woods earned 500 total points
ID: 36571356
I think this is the C# syntax:
  myResult = Regex.Replace(myString,@",(?!\s)",", ");
  myResult = Regex.Replace(myString,@"^\+\d\s?(\d{3})\s?(\d{3})\s?(\d{4})","($1) $2-$3");
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 

Author Comment

by:lapucca
ID: 36571358
So, using http://msdn.microsoft.com/en-us/library/e7f5w83z.aspx 
I'm not sure what to put for the replacement string for the Regex.Replace method though.  I mean what to put there so it would keep all the name's text and also adding that needed space after the comman?  Thanks.
0
 

Author Comment

by:lapucca
ID: 36571367
Terry, where can I find information on what is this $1, $2, $3.....  Is this grouping in regex?
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571371
Yes, it refers back to the 1st, 2nd and 3rd groups defined by the round brackets in the pattern.
0
 

Author Comment

by:lapucca
ID: 36571392
Ok, I can see that for the phone number.  However, I'm still not able to see that for the display name where I want to add a space where there isn't one.  The replacement string only has ", ".  That doesn't seem right, does it?
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571397
Yes - you're replacing a [comma without a space after it] with [a comma with a space after it]
0
 

Author Comment

by:lapucca
ID: 36571416
What about the rest of the Displayname's text?  Are you saying it only replaces the comman? so if i have this :
Mystring = "Doe,John";
Regext.Relace(Mystring, ",@",(?!\s)",", ");
now Mystring would contian "Doe, John"?
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571419
Yes, that's right.
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571420
Except there's an error in your code. It should be:
Regext.Relace(Mystring, @",(?!\s)",", ");
0
 

Author Closing Comment

by:lapucca
ID: 36571421
Thank you.
0
 
LVL 35

Expert Comment

by:Terry Woods
ID: 36571423
Correction!
Regex.Replace(Mystring, @",(?!\s)",", ");
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

This article describes a simple method to resize a control at runtime.  It includes ready-to-use source code and a complete sample demonstration application.  We'll also talk about C# Extension Methods. Introduction In one of my applications…
We all know that functional code is the leg that any good program stands on when it comes right down to it, however, if your program lacks a good user interface your product may not have the appeal needed to keep your customers happy. This issue can…
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…

820 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