473,387 Members | 1,579 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,387 software developers and data experts.

Regular expression

Hello

I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45

Invalid examples
-1
45-
1-45665456-4
12-45-
-

Thanks ;)

Oct 17 '07 #1
18 1700
On Wed, 17 Oct 2007 21:59:49 +0200, <da*******@gmail.comwrote:
Hello

I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45

Invalid examples
-1
45-
1-45665456-4
12-45-
-
Hmmz, showing a 'best try' would be appreciated. However, I normally can't
resist a good regex, so here it goes:

'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'
Untested BTW. I've made 78-034-89 invalid, as a number should not start
with zero, unless it's only 1 zero. 't Would be simpler if it was valid,
your choice.
--
Rik Wasmus
Oct 17 '07 #2
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-

Hmmz, showing a 'best try' would be appreciated. However, I normally can't
resist a good regex, so here it goes:

'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'

Untested BTW. I've made 78-034-89 invalid, as a number should not start
with zero, unless it's only 1 zero. 't Would be simpler if it was valid,
your choice.
--
Rik Wasmus
thanks ;)))

Oct 17 '07 #3
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-

Hmmz, showing a 'best try' would be appreciated. However, I normally can't
resist a good regex, so here it goes:

'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'

Untested BTW. I've made 78-034-89 invalid, as a number should not start
with zero, unless it's only 1 zero. 't Would be simpler if it was valid,
your choice.
--
Rik Wasmus
works like a charm, can you explain the simple way without check zero
at start?

thanks again

Oct 17 '07 #4
On Wed, 17 Oct 2007 22:50:59 +0200, <da*******@gmail.comwrote:
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
>On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-

Hmmz, showing a 'best try' would be appreciated. However, I normally
can't
resist a good regex, so here it goes:

'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'

Untested BTW. I've made 78-034-89 invalid, as a number should not start
with zero, unless it's only 1 zero. 't Would be simpler if it was valid,
your choice.

works like a charm, can you explain the simple way without check zero
at start?
'/^ # match start of string
[0-9]{1,3} # match 1 to 3 digits
( # start subpattern
- # literal -
[0-9]{1,3} # match 1 to 3 digits
)* # match subpattern zero or more times
$ # match has to run all the way up untill the end of the string
/x'

When starting with regexes, and certainly for the more complex ones, don't
underestimate the power of /x: comments in the regex itself, indentation
to keep things clear, it does wonders. It also keeps you from
rediscovering how the hell your regex worked 6 months after you wrote it
when you have to track a bug.....
--
Rik Wasmus
Oct 17 '07 #5
On 17 oct, 21:10, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 22:50:59 +0200, <davran...@gmail.comwrote:
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-
Hmmz, showing a 'best try' would be appreciated. However, I normally
can't
resist a good regex, so here it goes:
'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'
Untested BTW. I've made 78-034-89 invalid, as a number should not start
with zero, unless it's only 1 zero. 't Would be simpler if it was valid,
your choice.
works like a charm, can you explain the simple way without check zero
at start?

'/^ # match start of string
[0-9]{1,3} # match 1 to 3 digits
( # start subpattern
- # literal -
[0-9]{1,3} # match 1 to 3 digits
)* # match subpattern zero or more times
$ # match has to run all the way up untill the end of the string
/x'

When starting with regexes, and certainly for the more complex ones, don't
underestimate the power of /x: comments in the regex itself, indentation
to keep things clear, it does wonders. It also keeps you from
rediscovering how the hell your regex worked 6 months after you wrote it
when you have to track a bug.....
--
Rik Wasmus
Thanks !!! simple and beatifull

Oct 17 '07 #6

<da*******@gmail.comwrote in message
news:11**********************@q5g2000prf.googlegro ups.com...
On 17 oct, 21:10, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
>On Wed, 17 Oct 2007 22:50:59 +0200, <davran...@gmail.comwrote:
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers
separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-
>Hmmz, showing a 'best try' would be appreciated. However, I normally
can't
resist a good regex, so here it goes:
>'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'
>Untested BTW. I've made 78-034-89 invalid, as a number should not
start
with zero, unless it's only 1 zero. 't Would be simpler if it was
valid,
your choice.
works like a charm, can you explain the simple way without check zero
at start?

'/^ # match start of string
[0-9]{1,3} # match 1 to 3 digits
( # start subpattern
- # literal -
[0-9]{1,3} # match 1 to 3 digits
)* # match subpattern zero or more times
$ # match has to run all the way up untill the end
of the string
/x'

When starting with regexes, and certainly for the more complex ones,
don't
underestimate the power of /x: comments in the regex itself, indentation
to keep things clear, it does wonders. It also keeps you from
rediscovering how the hell your regex worked 6 months after you wrote it
when you have to track a bug.....
--
Rik Wasmus

Thanks !!! simple and beatifull
first, very good rik.

second, dave...if you're going to cross post the same question, at least
have the courtesy to go back and say, 'i found an answer, thanks for your
time.' shortly after your posting to alt.php, you had two responses...one of
which (not mine, btw), is much more simply expressed than rik's. either way,
be courteous to both of the groups you posted to...that way, we'll keep
responding to your questions rather than thinking that someone somewhere
else is responding.
Oct 18 '07 #7
On 18 oct, 05:40, "Steve" <no....@example.comwrote:
<davran...@gmail.comwrote in message

news:11**********************@q5g2000prf.googlegro ups.com...
On 17 oct, 21:10, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 22:50:59 +0200, <davran...@gmail.comwrote:
On 17 oct, 20:20, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Wed, 17 Oct 2007 21:59:49 +0200, <davran...@gmail.comwrote:
Hello
I need a regular expression that validate a list of numbers
separated
by "-" , numbers can not be greater than 999
Valid examples
0
12-455-01
1-9
125-32-155-45-45
Invalid examples
-1
45-
1-45665456-4
12-45-
-
Hmmz, showing a 'best try' would be appreciated. However, I normally
can't
resist a good regex, so here it goes:
'/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/'
Untested BTW. I've made 78-034-89 invalid, as a number should not
start
with zero, unless it's only 1 zero. 't Would be simpler if it was
valid,
your choice.
works like a charm, can you explain the simple way without check zero
at start?
'/^ # match start of string
[0-9]{1,3} # match 1 to 3 digits
( # start subpattern
- # literal -
[0-9]{1,3} # match 1 to 3 digits
)* # match subpattern zero or more times
$ # match has to run all the way up untill the end
of the string
/x'
When starting with regexes, and certainly for the more complex ones,
don't
underestimate the power of /x: comments in the regex itself, indentation
to keep things clear, it does wonders. It also keeps you from
rediscovering how the hell your regex worked 6 months after you wrote it
when you have to track a bug.....
--
Rik Wasmus
Thanks !!! simple and beatifull

first, very good rik.

second, dave...if you're going to cross post the same question, at least
have the courtesy to go back and say, 'i found an answer, thanks for your
time.' shortly after your posting to alt.php, you had two responses...one of
which (not mine, btw), is much more simply expressed than rik's. either way,
be courteous to both of the groups you posted to...that way, we'll keep
responding to your questions rather than thinking that someone somewhere
else is responding.
ok steve, excuse my poor english: I've post in 2 groups because the
question doesn't appear in the first group (comp.lang.javascript), I
don't like cross post, but you're right

A last question Rik :))), I was looking in http://regexlib.com a way
to do that and without an answer:

Same but numbers can't be lesser than the previous number, must be
equal or greater, is this possible with regex??

0-45-90-120 -Valid
0-45-45-90 -Valid
0-90-45-120 -Invalid

thanks

Oct 18 '07 #8
>you had two responses...one of
>which (not mine, btw), is much more simply expressed than rik's
Steve , not much more simply expressed

"1-9" and "\d" are identical ;)

Oct 18 '07 #9
On 18 Oct, 04:40, "Steve" <no....@example.comwrote:
second, dave...if you're going to cross post the same question, at least
have the courtesy to go back and say, 'i found an answer, thanks for your
time.' shortly after your posting to alt.php, you had two responses...one of
which (not mine, btw), is much more simply expressed than rik's. either way,
be courteous to both of the groups you posted to...that way, we'll keep
responding to your questions rather than thinking that someone somewhere
else is responding.
Actually Steve, if he had "cross-posted" ti wouldn't have been a
problem as both groups would have seen the responses.

So Dave, in future if you want to ask in 2 groups, do cross-post.

What you did in this case was multi-post.

See http://www.blakjak.demon.co.uk/mul_crss.htm

Oct 18 '07 #10
On Thu, 18 Oct 2007 10:42:20 +0200, <da*******@gmail.comwrote:
Same but numbers can't be lesser than the previous number, must be
equal or greater, is this possible with regex??

0-45-90-120 -Valid
0-45-45-90 -Valid
0-90-45-120 -Invalid
Maybe it's possible. I wouldn't do it with a regex anymore though.

function _my_validate($string){
$array = explode('-',$string);
if(!is_array($array)) return false;
$previous = 0;
foreach($array as $value){
if(
intval($value)!= $value
||
$value < $previous
||
$value 999
) return false;
$previous = $value;
}
return true;
}
--
Rik Wasmus
Oct 18 '07 #11
On 18 oct, 13:44, "Rik Wasmus" <luiheidsgoe...@hotmail.comwrote:
On Thu, 18 Oct 2007 10:42:20 +0200, <davran...@gmail.comwrote:
Same but numbers can't be lesser than the previous number, must be
equal or greater, is this possible with regex??
0-45-90-120 -Valid
0-45-45-90 -Valid
0-90-45-120 -Invalid

Maybe it's possible. I wouldn't do it with a regex anymore though.

function _my_validate($string){
$array = explode('-',$string);
if(!is_array($array)) return false;
$previous = 0;
foreach($array as $value){
if(
intval($value)!= $value
||
$value < $previous
||
$value 999
) return false;
$previous = $value;
}
return true;

}

--
Rik Wasmus
ok , thanks again

Oct 18 '07 #12

<da*******@gmail.comwrote in message
news:11*********************@v23g2000prn.googlegro ups.com...
you had two responses...one of
which (not mine, btw), is much more simply expressed than rik's

Steve , not much more simply expressed

"1-9" and "\d" are identical ;)
uhmmmm...

/^\d{1,3}(?:-\d{1,3})*$/

is much more simply understood than

/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/

smart ass.
Oct 18 '07 #13

"Captain Paralytic" <pa**********@yahoo.comwrote in message
news:11**********************@e34g2000pro.googlegr oups.com...
On 18 Oct, 04:40, "Steve" <no....@example.comwrote:
>second, dave...if you're going to cross post the same question, at least
have the courtesy to go back and say, 'i found an answer, thanks for your
time.' shortly after your posting to alt.php, you had two responses...one
of
which (not mine, btw), is much more simply expressed than rik's. either
way,
be courteous to both of the groups you posted to...that way, we'll keep
responding to your questions rather than thinking that someone somewhere
else is responding.

Actually Steve, if he had "cross-posted" ti wouldn't have been a
problem as both groups would have seen the responses.

So Dave, in future if you want to ask in 2 groups, do cross-post.

What you did in this case was multi-post.
yeah, yeah...lol

multi-post...i know. for christ's sake, i responded at 4.40 am...whatcha
expect. ;^)
Oct 18 '07 #14
On Thu, 18 Oct 2007 15:15:11 +0200, Steve <no****@example.comwrote:
>
<da*******@gmail.comwrote in message
news:11*********************@v23g2000prn.googlegro ups.com...
>you had two responses...one of
which (not mine, btw), is much more simply expressed than rik's

Steve , not much more simply expressed

"1-9" and "\d" are identical ;)

uhmmmm...

/^\d{1,3}(?:-\d{1,3})*$/

is much more simply understood than

/^([1-9][0-9]?)?[0-9](-([1-9][0-9]?)?[0-9])*$/

smart ass.
Because the first hasn't got the 'starting with 0 is prohibited unless
it's only one number'-clause.
The answer without that requirement is nearly identical, and I might say
perfectly readable:
'/^ # match start of string
[0-9]{1,3} # match 1 to 3 digits
( # start subpattern
- # literal -
[0-9]{1,3} # match 1 to 3 digits
)* # match subpattern zero or more times
$ # match has to run all the way up untill the end of the string
/x'

(which in one line would result in: '/^[0-9]{1,3}(-[0-9]{1,3})*$/')

Then again I have always had an unexpainable aversion against \d, don't
know why, I just always use [0-9].
--
Rik Wasmus
Oct 18 '07 #15
Greetings, da*******@gmail.com.
In reply to Your message dated Wednesday, October 17, 2007, 23:59:49,

dgcI need a regular expression that validate a list of numbers separated
dgcby "-" , numbers can not be greater than 999
dgcValid examples
dgc0
dgc12-455-01
dgc1-9
dgc125-32-155-45-45

dgcInvalid examples
dgc-1
dgc45-
dgc1-45665456-4
dgc12-45-
dgc-

dgcThanks ;)

Perl one:
^\d{1,3}(\-\d{1,3})*$
--
Sincerely Yours, AnrDaemon <an*******@freemail.ru>

Oct 19 '07 #16

"AnrDaemon" <an*******@freemail.ruwrote in message
news:72**********************@freemail.ru...
Greetings, da*******@gmail.com.
In reply to Your message dated Wednesday, October 17, 2007, 23:59:49,

dgcI need a regular expression that validate a list of numbers separated
dgcby "-" , numbers can not be greater than 999
dgcValid examples
dgc0
dgc12-455-01
dgc1-9
dgc125-32-155-45-45

dgcInvalid examples
dgc-1
dgc45-
dgc1-45665456-4
dgc12-45-
dgc-

dgcThanks ;)

Perl one:
^\d{1,3}(\-\d{1,3})*$
wow...thanks for that! it wasn't like that was posted in two newsgroups 4
days ago or anything...in the exact form of:

/^\d{1,3}(?:-\d{1,3})*$/

i suppose i should just wait till someone else answers a post and a couple
of days later, post the exact freaking thing. the redundancy, i think, would
just ensure that the op reeeeealy gets it.

lol.
Oct 19 '07 #17
Greetings, Steve.
In reply to Your message dated Friday, October 19, 2007, 23:10:56,

>dgcI need a regular expression that validate a list of numbers separated
dgcby "-" , numbers can not be greater than 999
dgcValid examples
dgc0
dgc12-455-01
dgc1-9
dgc125-32-155-45-45

dgcInvalid examples
dgc-1
dgc45-
dgc1-45665456-4
dgc12-45-
dgc-

dgcThanks ;)

Perl one:
^\d{1,3}(\-\d{1,3})*$
Swow...thanks for that! it wasn't like that was posted in two newsgroups 4
Sdays ago or anything...in the exact form of:

S/^\d{1,3}(?:-\d{1,3})*$/

Only difference is post-processing of result produced by this RE.
In my form You'll get set of subpatterns, in the form You referred above
You'll get only fullstring match and no subpatterns.
"(?: ... )" construction means grouping without storing, useful for in-line
multiplication of patterns.

Si suppose i should just wait till someone else answers a post and a couple
Sof days later, post the exact freaking thing. the redundancy, i think, would
Sjust ensure that the op reeeeealy gets it.

:) It was taking me longer than 2 months trying to figure out, how RE works
exactly and can it be used in real life. But after that, I can't live without
it.
--
Sincerely Yours, AnrDaemon <an*******@freemail.ru>

Oct 21 '07 #18

"AnrDaemon" <an*******@freemail.ruwrote in message
news:13**********************@freemail.ru...
Greetings, Steve.
In reply to Your message dated Friday, October 19, 2007, 23:10:56,

>>dgcI need a regular expression that validate a list of numbers
separated
dgcby "-" , numbers can not be greater than 999
dgcValid examples
dgc0
dgc12-455-01
dgc1-9
dgc125-32-155-45-45

dgcInvalid examples
dgc-1
dgc45-
dgc1-45665456-4
dgc12-45-
dgc-

dgcThanks ;)

Perl one:
^\d{1,3}(\-\d{1,3})*$

Swow...thanks for that! it wasn't like that was posted in two newsgroups
4
Sdays ago or anything...in the exact form of:

S/^\d{1,3}(?:-\d{1,3})*$/

Only difference is post-processing of result produced by this RE.
In my form You'll get set of subpatterns, in the form You referred above
You'll get only fullstring match and no subpatterns.
"(?: ... )" construction means grouping without storing, useful for
in-line
multiplication of patterns.
really? i had *no* idea! you mean, you can do that sort of thing? lol.

btw, that would be a great thing to tell the op...not me. further, you
should attempt to demonstrate that you actually know what ?: does. what you
have explained is COMPLETELY false! *grouping* does NOT mean *capturing*.
BOTH patterns GROUP. i've no idea on earth what 'multiplication of patterns'
means in regex...since multiplication is not part of any regex engine of
which i know.

to be clear to the op, ?: means that whatever is inbetween the parenthesis
will not be stored as matched output. and, since there is overhead in
capturing and given that the op ONLY wants to validate, it seems feckless to
quibble about the difference here as if yours provides a better solution. it
is the SAME regex pattern...only, yours will run slower.

Si suppose i should just wait till someone else answers a post and a
couple
Sof days later, post the exact freaking thing. the redundancy, i think,
would
Sjust ensure that the op reeeeealy gets it.

:) It was taking me longer than 2 months trying to figure out, how RE
works
exactly and can it be used in real life. But after that, I can't live
without
it.
and this means what, exactly? that you think posting identical solutions to
a problem advances the learning of the op? that's just silly.
Oct 22 '07 #19

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

Similar topics

1
by: Kenneth McDonald | last post by:
I'm working on the 0.8 release of my 'rex' module, and would appreciate feedback, suggestions, and criticism as I work towards finalizing the API and feature sets. rex is a module intended to make...
4
by: Buddy | last post by:
Can someone please show me how to create a regular expression to do the following My text is set to MyColumn{1, 100} Test I want a regular expression that sets the text to the following...
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...
11
by: Dimitris Georgakopuolos | last post by:
Hello, I have a text file that I load up to a string. The text includes certain expression like {firstName} or {userName} that I want to match and then replace with a new expression. However,...
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...
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...
1
by: Allan Ebdrup | last post by:
I have a dynamic list of regular expressions, the expressions don't change very often but they can change. And I have a single string that I want to match the regular expressions against and find...
1
by: NvrBst | last post by:
I want to use the .replace() method with the regular expression /^ %VAR % =,($|&)/. The following DOESN'T replace the "^default.aspx=,($|&)" regular expression with "":...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: aa123db | last post by:
Variable and constants Use var or let for variables and const fror constants. Var foo ='bar'; Let foo ='bar';const baz ='bar'; Functions function $name$ ($parameters$) { } ...
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
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
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
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...

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.