ChatGPT解决这个技术问题 Extra ChatGPT

Regular expression to limit number of characters to 10

I am trying to write a regular expression that will only allow lowercase letters and up to 10 characters. What I have so far looks like this:

pattern: /^[a-z]{0,10}+$/ 

This does not work or compile. I had a working one that would just allow lowercase letters which was this:

pattern: /^[a-z]+$/ 

But I need to limit the number of characters to 10.

The {} and the + do the same thing (counting), thus they are redundant, hence the error.
You should drop the '+' from /^[a-z]{0,10}+$/. It should be /^[a-z]{0,10}$/
Note that pattern ^[a-z]{0,10}+$ compiles on some languages and some of the notable ones are Java, Perl (5.10+), PHP, Ruby (1.9+). See this page for more detail.
See also universal solution via lookahead: Restricting Character length in Regular expression

L
LMD

You can use curly braces to control the number of occurrences. For example, this means 0 to 10:

/^[a-z]{0,10}$/

The options are:

{3} Exactly 3 occurrences;

{6,} At least 6 occurrences;

{,4} At most 4 occurrences;

{2,5} 2 to 5 occurrences.

See the regular expression reference.

Your expression had a + after the closing curly brace, hence the error.


In chrome dev tools with ember I had to ommit the beginning ^ to property match ONLY requests with a name like 1234 or 5678, and I had to include the $ sign
Note: be sure not to add a space between , and 10 ({0, 10} will not work).
J
Joren

/^[a-z]{0,10}$/ should work. /^[a-z]{1,10}$/ if you want to match at least one character, like /^[a-z]+$/ does.


j
jfarrell

It might be beneficial to add greedy matching to the end of the string, so you can accept strings > than 10 and the regex will only return up to the first 10 chars. /^[a-z0-9]{0,10}$?/


r
rink.attendant.6
grep '^[0-9]\{1,16\}' | wc -l

Gives the counts with exact match count with limit


P
Peter Mortensen

It very much depend on the program you're using. Different programs (Emacs, vi, sed, and Perl) use slightly different regular expressions. In this case, I'd say that in the first pattern, the last "+" should be removed.


R
Rochdi Belhirch
pattern: /[\w\W]{1,10}/g

I used this expression for my case, it includes all the characters available in the text.


This allows for whitespace which was not asked for.