Python - Extract range characters from String
Last Updated :
02 Jun, 2023
Given a String, extract characters only which lie between given letters.
Input : test_str = 'geekforgeeks is best', strt, end = "g", "s"
Output : gkorgksiss
Explanation : All characters after g and before s are retained.
Input : test_str = 'geekforgeeks is best', strt, end = "g", "r"
Output : gkorgki
Explanation : All characters after g and before r are retained.
Method #1 : Using list comprehension
In this, we check for character in range using comparison operation and list comprehension does task of iteration and creation of new list. Then join() can be employed to reconvert to string.
Python3
# Python3 code to demonstrate working of
# Extract range characters from String
# Using list comprehension
# initializing string
test_str = 'geekforgeeks is best'
# printing original string
print("The original string is : " + str(test_str))
# initializing range letters
strt, end = "f", "s"
# join() to get result in string
res = ''.join([chr for chr in test_str if chr >= strt and chr <= end])
# printing result
print("Extracted String : " + str(res))
OutputThe original string is : geekforgeeks is best
Extracted String : gkforgksiss
Method #2 : Using filter() + lambda + join()
Another way to solve this, in this, we perform task of comparison using lambda, and filter() used lambda function to get required characters.
Python3
# Python3 code to demonstrate working of
# Extract range characters from String
# Using filter() + lambda + join()
# initializing string
test_str = 'geekforgeeks is best'
# printing original string
print("The original string is : " + str(test_str))
# initializing range letters
strt, end = "f", "s"
# join() to get result in string
res = ''.join(list(filter(lambda chr : chr >= strt and chr <= end, test_str)))
# printing result
print("Extracted String : " + str(res))
OutputThe original string is : geekforgeeks is best
Extracted String : gkforgksiss
The Time and Space Complexity for all the methods are the same:
Time Complexity: O(n)
Space Complexity: O(n)
METHOD 3:Using re
APPROACH:
This program extracts a range of characters from a given string using regular expression and the findall() function.
ALGORITHM:
Initialize the original string and print it. Define the range of characters to extract. Define a regular expression pattern to match the characters within the given range. Use the findall() function with the pattern and the original string to extract all matches. Join the matches to form the extracted string. Print the extracted string.
Python3
import re
# initializing string
test_str = 'geekforgeeks is best'
# printing original string
print("The original string is : " + str(test_str))
# initializing range letters
strt, end = "f", "s"
# pattern to match characters within range
pattern = re.compile(f'[{strt}-{end}]')
# using findall() to extract all matches
matches = pattern.findall(test_str)
# joining the matches to get the extracted string
res = ''.join(matches)
# printing result
print("Extracted String : " + str(res))
OutputThe original string is : geekforgeeks is best
Extracted String : gkforgksiss
Time Complexity: The time complexity of this program depends on the length of the input string and the size of the character range. The findall() function has a time complexity of O(n), where n is the length of the input string. The join() function also has a time complexity of O(n), where n is the length of the resulting string. Overall, the time complexity of this program can be considered as O(n).
Space Complexity: The space complexity of this program depends on the length of the input string and the size of the character range. The program uses a regular expression pattern and a list to store the matches. The space complexity of the regular expression pattern is constant. The space complexity of the list is O(m), where m is the number of matches. Therefore, the space complexity of this program can be considered as O(m).
Similar Reads
Python - Extract only characters from given string To extract only characters (letters) from a given string we can use various easy and efficient methods in Python. Using str.isalpha() in a Loop str.isalpha() method checks if a character in a string is an alphabetic letter. Using a loop, we can iterate through each character in a string to filter ou
2 min read
Python program to extract characters in given range from a string list Given a Strings List, extract characters in index range spanning entire Strings list. Input : test_list = ["geeksforgeeks", "is", "best", "for", "geeks"], strt, end = 14, 20 Output : sbest Explanation : Once concatenated, 14 - 20 range is extracted.Input : test_list = ["geeksforgeeks", "is", "best",
4 min read
Get Last N characters of a string - Python We are given a string and our task is to extract the last N characters from it. For example, if we have a string s = "geeks" and n = 2, then the output will be "ks". Let's explore the most efficient methods to achieve this in Python.Using String Slicing String slicing is the fastest and most straigh
2 min read
Iterate over characters of a string in Python In this article, we will learn how to iterate over the characters of a string in Python. There are several methods to do this, but we will focus on the most efficient one. The simplest way is to use a loop. Letâs explore this approach.Using for loopThe simplest way to iterate over the characters in
2 min read
Python - Extract digits from given string We need to extract the digit from the given string. For example we are given a string s=""abc123def456gh789" we need to extract all the numbers from the string so the output for the given string will become "123456789" In this article we will show different ways to extract digits from a string in Py
2 min read