In Python Shell, I entered:
aList = ['a', 'b', 'c', 'd']
for i in aList:
print(i)
and got
a b c d
but when I tried:
aList = ['a', 'b', 'c', 'd']
aList = aList.append('e')
for i in aList:
print(i)
and got
Traceback (most recent call last):
File "<pyshell#22>", line 1, in <module>
for i in aList:
TypeError: 'NoneType' object is not iterable
Does anyone know what’s going on? How can I fix/get around it?
Answers:
Thank you for visiting the Q&A section on Magenaut. Please note that all the answers may not help you solve the issue immediately. So please treat them as advisements. If you found the post helpful (or not), leave a comment & I’ll get back to you as soon as possible.
Method 1
list.append is a method that modifies the existing list. It doesn’t return a new list — it returns None, like most methods that modify the list. Simply do aList.append('e') and your list will get the element appended.
Method 2
Generally, what you want is the accepted answer. But if you want the behavior of overriding the value and creating a new list (which is reasonable in some cases^), what you could do instead is use the “splat operator”, also known as list unpacking:
aList = [*aList, 'e'] #: ['a', 'b', 'c', 'd', 'e']
Or, if you need to support python 2, use the + operator:
aList = aList + ['e'] #: ['a', 'b', 'c', 'd', 'e']
^ There are many cases where you want to avoid the side effects of mutating with .append(). For one, imagine you want to append something to a list you’ve taken as a function argument. Whoever is using the function probably doesn’t expect that the list they provided is going to be changed. Using something like this keeps your function “pure” without “side effects”.
Method 3
Delete your second line aList = aList.append('e') and use only aList.append("e"), this should get rid of that problem.
Method 4
Sometimes this error appears when you forgot to return a function at the end of another function and passed an empty list, interpreted as NoneType.
from this:
def func1(): ... func2(empty_list) def func2(list): ... # use list here but it interpreted as NoneType
to this:
def func1():
...
return func2(empty_list)
def func2(list):
...
# use list here, it will be interpreted as an empty List
All methods was sourced from stackoverflow.com or stackexchange.com, is licensed under cc by-sa 2.5, cc by-sa 3.0 and cc by-sa 4.0