**Summary:** One of the following methods can be used to check if a list is empty :-

- Boolean operator
`not`

- Explicit check using
`len()`

- Simple Work Around With
`[]`

- Using
`.size()`

with NumPy - Using Exception Handling with
`iter()`

method

**Problem: **Given a list; how to check if it is empty?

**Example: **Consider the given list –

li = [] < Some Method To Check If List "li" Is Empty >

In this article let us quickly discuss the methods that can be used to check if a given list is empty. Without further delay let us dive into the solutions.

## Method 1: Using Implicit Boolean Operator “**not”**

The easiest and the most pythonic solution to our problem statement is to use a `Boolean `

operator to check if the list is empty. The table given below represents the `Boolean `

operations available at our disposal in Python for operations like the ones we have in our case.

Now let us have a look at the following program –

li = [] if not li: print(li, " is empty")

**Output:**

[] is empty

## Method 2: Performing Explicit Check Using “**len()”**

You can also check if the list is empty or not explicitly using the `len `

function.

`len()`

is an inbuilt method in Python that returns the length of an object. It can be very useful for conditional checks or performing iterations through objects like strings, list, tuple, etc.

Let us have a look at the following program to understand how we can use the `len()`

method to find the length of objects in Python and in the latter half of the program we will find out how we can leverage the `len()`

method to find how to know if the list is empty or not.

name = "FINXTER" d = {'name': 'FINXTER', 'founder': 'Christian Mayer'} tup = {0,1,2,3,4} li = [] # using len to fin out the length of the string name, tuple tup and dictionary d print("Length of string name is ",len(name)) print("Length of tuple tup is ",len(tup)) print("Length of dictionary d is ",len(d)) print("Length of list li is ",len(li)) print("\n***Using len() to check if list li is empty***") if len(li) == 0: print('The list li is Empty!') else: print(li)

**Output**

Length of string name is 7 Length of tuple tup is 5 Length of dictionary d is 2 Length of list li is 0 ***Using len() to check if list li is empty*** The list li is Empty!

From the above output it is evident that an empty list (or any other countable object) will have a length of zero.

## Method 3: A Simple Work Around With **[]**

Sometimes the easiest solutions are the ones that we don’t ponder upon thinking that they might not work. Here, let us discuss one such solution where you need not rack your brain to check if the list is empty. We can check if a given list is empty or not using the comparison operator `==`

that compares two objects in Python.

Let us have a look at the code to find out if this works in our case –

li = [] if li == [] : print ("List 'li' is Empty!")

**Output:**

List 'li' is Empty!

## Method 4: Using NumPy And **.size**

If you are using the `NumPy `

library in your code then I am afraid the above proposed methods won’t work for you because:

**1.** If your array is not empty then `NumPy `

casts the array to an array of `bools`

. So using the conditional` if x`

: will try to evaluate all of the `bools `

at once to achieve an aggregate truth value. This doesn’t make sense, so you will get a `ValueError.`

Also in case your array is empty, you will still get a similar warning as shown below:

**2.** The second problem is when you are using exactly one element in your `NumPy`

array. In this case, the conditional `if `

statement will work. However, if that one element in the array is **0** then though your program gets executed you won’t get the desired output because in this case, the `if`

conditional check will result in `False`

even though the array actually has an element in it i.e. 0.

**3. **The third issue is that when you use the inbuilt `len()`

method you might get unexpected outputs. For example, if you are using a two-dimensional array then you might be having 6 elements in the array but the `len()`

will only generate 2 based on the output based on the dimension of the array in use.

Let us have a look at the above discussed issues in a program given below :-

import numpy as np #Reason 2: Array with 0 as single element x = np.array([0,]) print("length of x is ",len(x)) # Reason 3: Unexpected results from len() a = np.array([[1,2], [3,4]]) print("length of a is ",len(a)) # Reason 1: ValueError li = np.array([0,1]) if not li: print(li)

**Output:**

length of x is 1 length of a is 2 Traceback (most recent call last): File "s1.py", line 15, in <module> if not li: ValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()

This brings us to the question, **What’s the NumPythonic Way?**

**T****he NumPythonic Way**

The correct way of checking if the array is empty in case of using the `NumPy `

library is given by using the

function. This inbuilt function of the NumPy library counts the number of elements in a given array along a given axis. If the default axis is not specified, it will take all the available axis into consideration.**size()**

Let us have a look at the following program which uses the `size`

function to overcome the shortcomings of the above methods :-

import numpy as np #Reason 2: Array with 0 as single element x = np.array([0,]) print("length of x is ",x.size) # Reason 3: Solution to len() a = np.array([[1,2], [3,4]]) print("length of a is ",a.size) # Reason 1: Solution to ValueError li = np.array([]) if not li.size: print(li, "is Empty!")

**Output:**

length of x is 1 length of a is 4 [] is Empty!

## Method 5: Using **Exception **and **iter()**

This might be a silly approach but nevertheless, it works. So let us have a look at how we can use exception handling along with `iter()`

method to solve our problem.

li = [] try: x = next(iter(li)) print(x) except StopIteration: print("li is empty")

**Output:**

li is empty

**Note:-** `iter()`

is an inbuilt method in Python which creates an iterable object that can be iterated with one element at a time.

## Conclusion

I hope the methods discussed in this article help you to detect the presence of elements in a list and use them accordingly in your code. Please subscribe and stay tuned for more interesting articles!

## Where to Go From Here?

Enough theory. Letโs get some practice!

Coders get paid six figures and more because they can solve problems more effectively using machine intelligence and automation.

To become more successful in coding, solve more real problems for real people. Thatโs how you polish the skills you really need in practice. After all, whatโs the use of learning theory that nobody ever needs?

**You build high-value coding skills by working on practical coding projects!**

Do you want to stop learning with toy projects and focus on practical code projects that earn you money and solve real problems for people?

๐ If your answer is ** YES!**, consider becoming a Python freelance developer! Itโs the best way of approaching the task of improving your Python skillsโeven if you are a complete beginner.

If you just want to learn about the freelancing opportunity, feel free to watch my free webinar โHow to Build Your High-Income Skill Pythonโ and learn how I grew my coding business online and how you can, tooโfrom the comfort of your own home.