473,397 Members | 1,949 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,397 software developers and data experts.

Regular expression help

I am trying to write a regular expression to cover US currency, where the
dollar sign and cents are optional. The following string worked when I used
it in the ValidationExpression field of a RegularExpressionValidator
control:

[$]?\d{1,10}([.]\d{2})?

However, when I tried to make a function using this expression, it would not
validate properly, allowing as many numbers after the decimal point as
desired, and also allowing more than 10 numbers for dollars. For now, I've
come up with the following that does validate properly, included in the
function I'm trying to write below:

public static bool isMoney(string pValue)
{
Regex lReg;
lReg = new Regex("\\b[$]?\\d{1,10}[.]\\d{2}\\b");
if (pValue.Trim().Length==0)
{
return true;
}
return lReg.IsMatch(pValue);
}

That will validate the dollar sign and dollar-number range (1-10 digits),
but when I tried to make the cents portion optional, all of the validation
stopped working properly. I also had to add the \b characters to encapsulate
the string, again so it would work properly.

Any assistance in fixing this up would be appreciated. Thanks.

--

Kenneth S. McAndrew
Software Developer, Information Concepts
km*******@infoconcepts.com

Nov 15 '05 #1
2 4825
"Ken McAndrew" <km*******@infoconcepts.com> wrote in
news:ur**************@TK2MSFTNGP09.phx.gbl:
I am trying to write a regular expression to cover US currency, where
the dollar sign and cents are optional. The following string worked
when I used it in the ValidationExpression field of a
RegularExpressionValidator control:


not specific help for your specific problem, but here's a tool that can
help you get the right format quicker than building into a program and
running and testing... called Expresso.

http://www.codeproject.com/dotnet/expresso.asp

-mdb
Nov 15 '05 #2
Hi,
[inline]
"Ken McAndrew" <km*******@infoconcepts.com> wrote in message
news:ur**************@TK2MSFTNGP09.phx.gbl...
I am trying to write a regular expression to cover US currency, where the
dollar sign and cents are optional. The following string worked when I used it in the ValidationExpression field of a RegularExpressionValidator
control:

[$]?\d{1,10}([.]\d{2})?
Should be:

string rex = "^\\$?\\d{0,10}(\\.\\d{2})?$";

Where:
^ begin of text
$ end of text

Now you can see that the literal $ must be escaped, and so does the literal
period. Because a period means any character except \r\n (if singleline
option is not set) for regex.

You don't need character groups ([]) for a single literal.

HTH
greetings


However, when I tried to make a function using this expression, it would not validate properly, allowing as many numbers after the decimal point as
desired, and also allowing more than 10 numbers for dollars. For now, I've
come up with the following that does validate properly, included in the
function I'm trying to write below:

public static bool isMoney(string pValue)
{
Regex lReg;
lReg = new Regex("\\b[$]?\\d{1,10}[.]\\d{2}\\b");
if (pValue.Trim().Length==0)
{
return true;
}
return lReg.IsMatch(pValue);
}

That will validate the dollar sign and dollar-number range (1-10 digits),
but when I tried to make the cents portion optional, all of the validation
stopped working properly. I also had to add the \b characters to encapsulate the string, again so it would work properly.

Any assistance in fixing this up would be appreciated. Thanks.

--

Kenneth S. McAndrew
Software Developer, Information Concepts
km*******@infoconcepts.com

Nov 15 '05 #3

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

5
by: Bradley Plett | last post by:
I'm hopeless at regular expressions (I just don't use them often enough to gain/maintain knowledge), but I need one now and am looking for help. I need to parse through a document to find a URL,...
4
by: Neri | last post by:
Some document processing program I write has to deal with documents that have headers and footers that are unnecessary for the main processing part. Therefore, I'm using a regular expression to go...
10
by: Lee Kuhn | last post by:
I am trying the create a regular expression that will essentially match characters in the middle of a fixed-length string. The string may be any characters, but will always be the same length. In...
3
by: James D. Marshall | last post by:
The issue at hand, I believe is my comprehension of using regular expression, specially to assist in replacing the expression with other text. using regular expression (\s*) my understanding is...
7
by: Billa | last post by:
Hi, I am replaceing a big string using different regular expressions (see some example at the end of the message). The problem is whenever I apply a "replace" it makes a new copy of string and I...
9
by: Pete Davis | last post by:
I'm using regular expressions to extract some data and some links from some web pages. I download the page and then I want to get a list of certain links. For building regular expressions, I use...
3
by: Zach | last post by:
Hello, Please forgive if this is not the most appropriate newsgroup for this question. Unfortunately I didn't find a newsgroup specific to regular expressions. I have the following regular...
25
by: Mike | last post by:
I have a regular expression (^(.+)(?=\s*).*\1 ) that results in matches. I would like to get what the actual regular expression is. In other words, when I apply ^(.+)(?=\s*).*\1 to " HEART...
3
by: Mr.Steskal | last post by:
Posted: Wed Jul 11, 2007 7:01 am Post subject: Regular Expression Help -------------------------------------------------------------------------------- I need help writing a regular...
18
by: Lit | last post by:
Hi, I am looking for a Regular expression for a password for my RegExp ValidationControl Requirements are, At least 8 characters long. At least one digit At least one upper case character
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.