Python Regex – Program to accept string starting with vowel
Last Updated :
23 Apr, 2023
Prerequisite: Regular expression in Python
Given a string, write a Python program to check whether the given string is starting with Vowel or Not.
Examples:
Input: animal
Output: Accepted
Input: zebra
Output: Not Accepted
In this program, we are using search() method of re module.
re.search() : This method either returns None (if the pattern doesn’t match), or re.MatchObject that contains information about the matching part of the string. This method stops after the first match, so this is best suited for testing a regular expression more than extracting data.
Let’s see the Python program for this :
Python3
import re
regex = '^[aeiouAEIOU][A-Za-z0-9_]*'
def check(string):
if (re.search(regex, string)):
print ( "Valid" )
else :
print ( "Invalid" )
if __name__ = = '__main__' :
string = "ankit"
check(string)
string = "geeks"
check(string)
string = "sandeep"
check(string)
|
Output:
Valid
Invalid
Invalid
Using re.findall:
We are using the re module to work with regular expressions in Python. The re.findall method is used to search for all the occurrences of the regular expression in the given string. If a match is found, it returns a list containing the matches. If no match is found, it returns an empty list.
We have defined a regular expression to match strings that start with a vowel (either uppercase or lowercase). The regular expression ‘^[aeiouAEIOU][A-Za-z0-9_]*’ means:
- ^ matches the start of a string
- [aeiouAEIOU] matches any of the characters a, e, i, o, u, A, E, I, O, U
- [A-Za-z0-9_]* matches any character in the range A-Z, a-z, 0-9, or _, zero or more times
We pass the regular expression and the string to the re.findall method. If a match is found, the match variable will contain a list with the matching string. If no match is found, the match variable will be an empty list. We can then check if the match variable is non-empty to determine if the string starts with a vowel or not.
Python3
import re
def check(string):
regex = '^[aeiouAEIOU][A-Za-z0-9_]*'
match = re.findall(regex, string)
if match:
print ( "Valid" )
else :
print ( "Invalid" )
if __name__ = = '__main__' :
string = "ankit"
check(string)
string = "geeks"
check(string)
string = "sandeep"
check(string)
|
Output
Valid
Invalid
Invalid
Time complexity: O(n) where n is the length of the string
Auxiliary Space: O(n)
Approach#3: Using re.match()
This approach problem can be solved using regular expressions. We create a pattern that matches strings starting with any vowel (lowercase or uppercase). Then, we use re.match to check if the given string matches the pattern. If it does, we return “Accepted”. Otherwise, we return “Not Accepted”.
Algorithm
1. Define the function starts_with_vowel that takes a string s as input.
2. Create a pattern that matches strings starting with any vowel (lowercase or uppercase).
3. Use re.match to check if the given string s matches the pattern.
4. If s matches the pattern, return “Accepted”. Otherwise, return “Not Accepted”.
Python3
import re
def starts_with_vowel(s):
pattern = '^[aeiouAEIOU].*'
if re.match(pattern, s):
return "Accepted"
else :
return "Not Accepted"
s1 = "animal"
s2 = "zebra"
print (starts_with_vowel(s1))
print (starts_with_vowel(s2))
|
Output
Accepted
Not Accepted
Time complexity: O(n), where n is the length of the input string s. This is because we are using the re.match() function, which takes linear time to match the pattern with the input string.
Space complexity: O(1), as we are only creating a single regular expression pattern and a few string variables that do not scale with the input size.
Like Article
Suggest improvement
Share your thoughts in the comments
Please Login to comment...