6

Count Occurrences of a character in String in Python

 2 years ago
source link: https://thispointer.com/count-occurrences-of-a-character-in-string-in-python/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

In this article, we will learn to count the number of occurrences of a character in a given string using Python.

Table Of Contents

What are Strings ?

A String is an array of bytes, representing Unicode characters enclosed in single, double or triple quotes. The Enclosed characters can be any digit, alphabets or special symbols. A String is just a normal text and is human readable. Strings in Python are immutable, means that can not be changed.

Now we will look at various methods through which we can count the number of occurrences of a character in a string.

Count occurrences of a character in string using count():

First method that we will learn is count() method of string class. It takes a character as an argument and returns the number of occurrence of the given character in the calling string object.

Advertisements

00:00/15:21
liveView.php?hash=ozcmPTEznXRiPTEzqzyxX2V2ZW50PTUjJaNypaZypyRcoWU9MTY1Mmp2MwE4NSZ2nWRspGkurWVlVzVlPTMhMS4jJaM9MTAkMwx3JaN0YT0jJat9NDUmJax9MmI1JaZcZF9jYXNmRG9gYWyhPXRbnXNjo2yhqGVlLzNioSZmqWJJZD10nGympG9coaRypv5wo20zZGVvqWqJozZipz1uqGyiow1BQyQyMwAyMxYyMwBmY2uunW4yMwAyMxYyMwAlJTIjJTJGJTIjZGVzYXVfqCZcp0FjpD0jJaNxn3Y9JaJcPTZDNwx3NwY1NTM3NDYkNmQ3MmqDNmM2QwMkN0I1NDMjN0Q3QwY0MmImMDMlMmIlRDMjMmUlRDMlMmt1RwMlMmE3RDqCNmMmMTMlMmMmNDM5MmYmNDM5N0Q3QwQmMmImNDM3N0Q3QwUmNwQ0NmY4NmA2MmMmNDI3NwYkNTpmNTMjNUE1ODQ5NmU1OTMlMmx3NDqEN0I2MwYmNwt3MwZGNxQ2NTqEN0I3MTY0NwU3MmZCNmQ2RwpjN0Q3QwZGNxM2OTZFNmU3ODqEN0I1ODM0MmUmMmqEN0I1OTMmMmImNTqEN0I2NwMkN0Q3QwplNTE1NTRBNTU0OTQmMmt2NmYmMmI0RTZGNTx1NmZDNmU0OTQmMmt2NmRENwx0MTp2NDx0NmUlNxM1QTZENDYmMTYlNDt1MTNEN0Q3QwRDMmEmMwM1MmImMTqERxVGRSZxnWFcZD0zqXNypxyjQWRxpw01MC43LwI1Ml4kNmIzqXNypyVBPU1irzyfoGEyMxY1LwAyMwAyMwuYMTEyM0IyMwBMnW51rCUlMHt4Ny82NCUlOSUlMEFjpGkyV2VvS2y0JTJGNTM3LwM2JTIjJTI4S0uUTUjyMxMyMwBfnWgyJTIjR2Vwn28yMwxyMwBIZWFxoGVmp0Nbpz9gZSUlRwEjMS4jLwQ5NTEhNwQyMwBTYWZupzxyMxY1MmphMmYzY3N1qWyxPTYlOTI2ODt5MwY0NmpzY29hqGVhqEZcoGVJZD0jJz1yZGyuUGkurUkcp3RJZD0jJz1yZGyuTGymqEyxPTAzZ2Rjpw0jJzqxpHJDo25mZW50PSZcp1qyUGFmp0qxpHI9MSZwY3BuPTAzY2NjYUNioaNyoaQ9JzNvqXN0ZXI9MTY1Mmp2MwE4NwM2NSZ1nWQ9U2VenW5xo1NQoGF5ZXI2MwxlNwt4OWJuZWU4JaB1YyVloD1bqHRjplUmQSUlRvUlRaRbnXNjo2yhqGVlLzNioSUlRzNiqW50LW9wY3VlpzVhY2VmLW9zLWEgY2uupzFwqGVlLWyhLXN0pzyhZl1cov1jrXRbo24yMxYzZzkiYXRTqGF0qXM9ZzFfp2UzZWyxp3A9pHJyYzyxliveView.php?hash=ozcmPTEznXRiPTEzqzyxX2V2ZW50PTI1JaNypaZypyRcoWU9MTY1Mmp2MwE4NSZ2nWRspGkurWVlVzVlPTMhMS4jJaM9MTAkMwx3JaN0YT0jJat9NDUmJax9MmI1JaZcZF9jYXNmRG9gYWyhPXRbnXNjo2yhqGVlLzNioSZmqWJJZD10nGympG9coaRypv5wo20zZGVvqWqJozZipz1uqGyiow1BQyQyMwAyMxYyMwBmY2uunW4yMwAyMxYyMwAlJTIjJTJGJTIjZGVzYXVfqCZcp0FjpD0jJaNxn3Y9JaVmZXJJpEFxZHI9NTAhNl4lNTMhMTplJaVmZXJVQT1No3ccoGkuJTJGNS4jJTIjJTI4WDEkJTNCJTIjTGyhqXtyMwB4ODZsNwQyMwxyMwBBpHBfZVqyYxgcqCUlRwUmNl4mNvUlMCUlOEgIVE1MJTJDJTIjoGyeZSUlMEqyY2giJTI5JTIjSGVuZGkyp3NDnHJioWUyMxYkMDEhMC40OTUkLwY0JTIjU2FzYXJcJTJGNTM3LwM2JzNmqXVcZD02MwxlNwt4OTI2NDp3JzNioaRyoaRGnWkySWQ9MCZgZWRcYVBfYXyMnXN0SWQ9MCZgZWRcYUkcp3RJZD0jJzR1pw04MDAzZ2Rjpw0jJzqxpHJDo25mZW50PSZcp1qyUGFmp0qxpHI9MSZwY3BuPTAzY2NjYUNioaNyoaQ9JzNvqXN0ZXI9MTY1Mmp2MwE5NDM4NlZ1nWQ9U2VenW5xo1NQoGF5ZXI2MwxlNwt4OWJuZWU4JaB1YyVloD1bqHRjplUmQSUlRvUlRaRbnXNjo2yhqGVlLzNioSUlRzNiqW50LW9wY3VlpzVhY2VmLW9zLWEgY2uupzFwqGVlLWyhLXN0pzyhZl1cov1jrXRbo24yMxYzZzkiYXRTqGF0qXM9ZzFfp2UzZWyxp3A9pHJyYzyxliveView.php?hash=ozcmPTEznXRiPTEzqzyxX2V2ZW50PTI1JaNypaZypyRcoWU9MTY1Mmp2MwE4NSZ2nWRspGkurWVlVzVlPTMhMS4jJaM9MTAkMwx3JaN0YT0jJat9NDUmJax9MmI1JaZcZF9jYXNmRG9gYWyhPXRbnXNjo2yhqGVlLzNioSZmqWJJZD10nGympG9coaRypv5wo20zZGVvqWqJozZipz1uqGyiow1BQyQyMwAyMxYyMwBmY2uunW4yMwAyMxYyMwAlJTIjJTJGJTIjZGVzYXVfqCZcp0FjpD0jJaNxn3Y9JaVmZXJJpEFxZHI9NTAhNl4lNTMhMTplJaVmZXJVQT1No3ccoGkuJTJGNS4jJTIjJTI4WDEkJTNCJTIjTGyhqXtyMwB4ODZsNwQyMwxyMwBBpHBfZVqyYxgcqCUlRwUmNl4mNvUlMCUlOEgIVE1MJTJDJTIjoGyeZSUlMEqyY2giJTI5JTIjSGVuZGkyp3NDnHJioWUyMxYkMDEhMC40OTUkLwY0JTIjU2FzYXJcJTJGNTM3LwM2JzNmqXVcZD02MwxlNwt4OTI2NDp3JzNioaRyoaRGnWkySWQ9MCZgZWRcYVBfYXyMnXN0SWQ9MCZgZWRcYUkcp3RJZD0jJzR1pw02MwpzZ2Rjpw0jJzqxpHJDo25mZW50PSZcp1qyUGFmp0qxpHI9MSZwY3BuPTAzY2NjYUNioaNyoaQ9JzNvqXN0ZXI9MTY1Mmp2MwIjMDY1NCZ1nWQ9U2VenW5xo1NQoGF5ZXI2MwxlNwt4OWJuZWU4JaB1YyVloD1bqHRjplUmQSUlRvUlRaRbnXNjo2yhqGVlLzNioSUlRzNiqW50LW9wY3VlpzVhY2VmLW9zLWEgY2uupzFwqGVlLWyhLXN0pzyhZl1cov1jrXRbo24yMxYzZzkiYXRTqGF0qXM9ZzFfp2UzZWyxp3A9pHJyYzyx

It is the most simple method, but its drawback is, that it counts upper case and lower case alphabets as different characters.

For example : If string is “He is Standing below a Tree”. There are two “t”, one is in Upper case and other in lower. Lets see what is the outputs :

CODE :

string_var = 'He is Standing below a Tree'
print( string_var.count('t') )
string_var = 'He is Standing below a Tree'

print( string_var.count('t') )

OUTPUT :

You can see in above code, number of occurrences of character ‘t’ is 1, but the number of ‘t’ (both in lower and upper case) is 2. So this method can be used to count the occurrence of character in a string but it counts upper and lower case separately.

Count occurrences of a character in string using collections.counter():

Next method through which we can accomplish our job is by using the counter() method of Collections module.

The Collections module of python, provides different types of containers. Which provides an aleternative way to contain objects and iterate over them. It provides us different types of containers such as : Counters, ChainMap, DefaultMap, etc..

We will be using counter(). It is a dictionary subclass which sotres the elements as dictionary keys and their occurrence is stored as their values. It returns zero for items that are not present. Lets see an example.

CODE :

from collections import Counter
string_var = 'He is Standing below a Tree'
count = Counter(string_var)
# this will print dict count
print(count)
# this will print number of occurrence of char e
print('occurrence of alphabet e',count['t'])
from collections import Counter

string_var = 'He is Standing below a Tree'

count = Counter(string_var) 

# this will print dict count
print(count)  

# this will print number of occurrence of char e
print('occurrence of alphabet e',count['t'])

OUTPUT :

Counter({' ': 5, 'e': 4, 'i': 2, 'a': 2, 'n': 2, 'H': 1, 's': 1, 'S': 1, 't': 1, 'd': 1, 'g': 1, 'b': 1, 'l': 1, 'o': 1, 'w': 1, 'T': 1, 'r': 1})
occurrence of alphabet e 1
Counter({' ': 5, 'e': 4, 'i': 2, 'a': 2, 'n': 2, 'H': 1, 's': 1, 'S': 1, 't': 1, 'd': 1, 'g': 1, 'b': 1, 'l': 1, 'o': 1, 'w': 1, 'T': 1, 'r': 1})
occurrence of alphabet e 1

In code above, the objective is to find the number of occurrences of char e in variable str_var. In variablr count , the Counter() method of Collections module has been initalized and now count variable stores a dictionary with alpahbets as key and their occurrence count as value. It also counts upper and lower case alphabets separately.

Count occurrences of a character in string using re.findall() :

Next method that we will be using to find the occurrence of a given char is findall() method of re module. The re stands for Regular Expression, which comes bundled with python library that uses backslash character (‘\’) to indicate special forms. The re.findall() scans the given string from left to right and checks if the given string has a specified pattern which may be in the form of digits or any other data type. Here we will use findall() and len() method to print the occurrence of the given string.
See an Example below.

EXAMPLE :

import re
string_var = 'He is Standing below a Tree'
occurrence = re.findall('e',string_var)
# this will print list occurrence with all e chars
print(occurrence)
# this will print the count of occurrences
print(len(occurrence))
import re 

string_var = 'He is Standing below a Tree'

occurrence = re.findall('e',string_var) 

# this will print list occurrence with all e chars
print(occurrence) 

# this will print the count of occurrences
print(len(occurrence)) 

OUTPUT :

['e', 'e', 'e', 'e']
['e', 'e', 'e', 'e']
4

In example above, the findall() method of the re module has been used to count the occurrence of char t in var string_var. Here, re.findall() returns strings in a list and len() method counts the length of list. This way we can find how many times the given char is in the string. This method also counts upper case and lower case separately.

Count occurrences of a character in string using defaultdict()

The defaultdict() method comes with the collections module in Python. Its functionality is similar to dictionary class, and it stores chars as keys and their occurrence count as values.It also provides a default value for the key that never exists. Lets see an example :

CODE :

from collections import defaultdict
string_var = 'He is Standing below a Tree'
occurrence = defaultdict(int)
for i in string_var:
occurrence[i] += 1
print(occurrence['e'])
from collections import defaultdict

string_var = 'He is Standing below a Tree'

occurrence = defaultdict(int)

for i in string_var:
    occurrence[i] += 1

print(occurrence['e'])

OUTPUT :

4

In code above you can see defaultdict() method has been used to count the occurrence of the char ‘e’ in variable string_var. It also counts upper case and lower case separately.

Using using pandas.series

In this method we will be using the series.value_count() of Pandas package to count the number of occurrences of a character in a given string. Pandas is a data analysis tool widely used. Here we will be using pandas series, which is a 1-D ndarray with axis labels.

pandas.series.value_counts() reurns a sereis with counts of unique values in descending order and the first element is always the most occuring element.

SYNTAX : pd.Series.value_counts(normalize,sort,ascending,bins,dropna)

PARAMETER : It recieves five parameters :

  • normalize : If true this returns the frequency of unique values.Default value is False.
  • sort : Sort by the given values.Default value is True
  • ascending : Sort in ascending order.Default value is False.
  • bins : Default value is None/
  • dropna : Doesn’t includes count of NaN.

Lets See an example of this method :

CODE :

import pandas as pd
string_var = 'He is Standing below a Tree'
print( pd.Series(list(string_var)).value_counts() )
import pandas as pd

string_var = 'He is Standing below a Tree'

print( pd.Series(list(string_var)).value_counts() )

OUTPUT :

dtype: int64
     5
e    4
i    2
n    2
a    2
l    1
T    1
S    1
s    1
r    1
o    1
H    1
g    1
b    1
t    1
d    1
w    1
dtype: int64

In code and Output above, you can see series.value_count() method of pandas package has been used to count the occurrence of a given char in a string. This method has returned all the occurrences of all characters in a Series object.

Summary

So you have seen five different methods through which we can count the number of occurrences of a character in a string. All the methods above count upper case and lower case methods separately. The most easy method is count() method because it recieves a string as a parameter and returns the number of occurrence. For most detail count and values you can use sereies.count_values() method of pandas package which is widely used for data analysis.

Pandas Tutorials -Learn Data Analysis with Python

 

 

Are you looking to make a career in Data Science with Python?

Data Science is the future, and the future is here now. Data Scientists are now the most sought-after professionals today. To become a good Data Scientist or to make a career switch in Data Science one must possess the right skill set. We have curated a list of Best Professional Certificate in Data Science with Python. These courses will teach you the programming tools for Data Science like Pandas, NumPy, Matplotlib, Seaborn and how to use these libraries to implement Machine learning models.

Checkout the Detailed Review of Best Professional Certificate in Data Science with Python.

Remember, Data Science requires a lot of patience, persistence, and practice. So, start learning today.

Join a LinkedIn Community of Python Developers

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK