Skip to content
Advertisement

In Python, how to check if a string only contains certain characters?

In Python, how to check if a string only contains certain characters?

I need to check a string containing only a..z, 0..9, and . (period) and no other character.

I could iterate over each character and check the character is a..z or 0..9, or . but that would be slow.

I am not clear now how to do it with a regular expression.

Is this correct? Can you suggest a simpler regular expression or a more efficient approach.

JavaScript

Advertisement

Answer

Final(?) edit

Answer, wrapped up in a function, with annotated interactive session:

JavaScript

Note: There is a comparison with using re.match() further down in this answer. Further timings show that match() would win with much longer strings; match() seems to have a much larger overhead than search() when the final answer is True; this is puzzling (perhaps it’s the cost of returning a MatchObject instead of None) and may warrant further rummaging.

JavaScript

The [previously] accepted answer could use a few improvements:

(1) Presentation gives the appearance of being the result of an interactive Python session:

JavaScript

but match() doesn’t return True

(2) For use with match(), the ^ at the start of the pattern is redundant, and appears to be slightly slower than the same pattern without the ^

(3) Should foster the use of raw string automatically unthinkingly for any re pattern

(4) The backslash in front of the dot/period is redundant

(5) Slower than the OP’s code!

JavaScript

(6) Can produce the wrong answer!!

JavaScript
User contributions licensed under: CC BY-SA
6 People found this is helpful
Advertisement