data:image/s3,"s3://crabby-images/8dc27/8dc27f4d3d83168cf820f98a39b437e65bb48b34" alt=""
Constructing Lists in Python
Constructing Lists in Python 관련
data:image/s3,"s3://crabby-images/c8a48/c8a48d4765e390b9fd456a88f0cb13be8aa527cb" alt=""
data:image/s3,"s3://crabby-images/c8a48/c8a48d4765e390b9fd456a88f0cb13be8aa527cb" alt=""
First things first. If you want to use a list to store or collect some data in your code, then you need to create a list object. You’ll find several ways to create lists in Python. That’s one of the features that make lists so versatile and popular.
For example, you can create lists using one of the following tools:
- List literals
- The
list()
constructor - A list comprehension
In the following sections, you’ll learn how to use the three tools listed above to create new lists in your code. You’ll start off with list literals.
Creating Lists Through Literals
List literals are probably the most popular way to create a list
object in Python. These literals are fairly straightforward. They consist of a pair of square brackets enclosing a comma-separated series of objects.
Here’s the general syntax of a list literal:
[item_0, item_1, ..., item_n]
This syntax creates a list of n
items by listing the items in an enclosing pair of square brackets. Note that you don’t have to declare the items’ type or the list’s size beforehand. Remember that lists have a variable size and can store heterogeneous objects.
Here are a few examples of how to use the literal syntax to create new lists:
digits = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
fruits = ["apple", "banana", "orange", "kiwi", "grape"]
cities = [
"New York",
"Los Angeles",
"Chicago",
"Houston",
"Philadelphia"
]
matrix = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
]
inventory = [
{"product": "phone", "price": 1000, "quantity": 10},
{"product": "laptop", "price": 1500, "quantity": 5},
{"product": "tablet", "price": 500, "quantity": 20}
]
functions = [print, len, range, type, enumerate]
empty = []
In these examples, you use the list literal syntax to create lists containing numbers, strings, other lists, dictionaries, and even function objects. As you already know, lists can store any type of object. They can also be empty, like the final list in the above code snippet.
Empty lists are useful in many situations. For example, maybe you want to create a list of objects resulting from computations that run in a loop. The loop will allow you to populate the empty list one element at a time.
Using a list literal is arguably the most common way to create lists. You’ll find these literals in many Python examples and codebases. They come in handy when you have a series of elements with closely related meanings, and you want to pack them into a single data structure.
Note that naming lists as plural nouns is a common practice that improves readability. However, there are situations where you can use collective nouns as well.
For example, you can have a list called people
. In this case, every item will be a person
. Another example would be a list that represents a table in a database. You can call the list table
, and each item will be a row
. You’ll find more examples like these in your walk-through of using lists.
Using the list()
Constructor
Another tool that allows you to create list
objects is the class constructor, list()
. You can call this constructor with any iterable object, including other lists, tuples, sets, dictionaries and their components, strings, and many others. You can also call it without any arguments, in which case you’ll get an empty list back.
Here’s the general syntax:
list([iterable])
To create a list, you need to call list()
as you’d call any class constructor or function. Note that the square brackets around iterable
mean that the argument is optional, so the brackets aren’t part of the syntax. Here are a few examples of how to use the constructor:
list((0, 1, 2, 3, 4, 5, 6, 7, 8, 9))
#
# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
list({"circle", "square", "triangle", "rectangle", "pentagon"})
#
# ['square', 'rectangle', 'triangle', 'pentagon', 'circle']
list({"name": "John", "age": 30, "city": "New York"}.items())
#
# [('name', 'John'), ('age', 30), ('city', 'New York')]
list("Pythonista")
#
# ['P', 'y', 't', 'h', 'o', 'n', 'i', 's', 't', 'a']
list()
#
# []
In these examples, you create different lists using the list()
constructor, which accepts any type of iterable object, including tuples, dictionaries, strings, and many more. It even accepts sets, in which case you need to remember that sets are unordered data structures, so you won’t be able to predict the final order of items in the resulting list.
Calling list()
without an argument creates and returns a new empty list. This way of creating empty lists is less common than using an empty pair of square brackets. However, in some situations, it can make your code more explicit by clearly communicating your intent: creating an empty list.
The list()
constructor is especially useful when you need to create a list out of an iterator object. For example, say that you have a generator function that yields numbers from the Fibonacci sequence on demand, and you need to store the first ten numbers in a list.
In this case, you can use list()
as in the code below:
def fibonacci_generator(stop):
current_fib, next_fib = 0, 1
for _ in range(0, stop):
fib_number = current_fib
current_fib, next_fib = next_fib, current_fib + next_fib
yield fib_number
fibonacci_generator(10)
#
# <generator object fibonacci_generator at 0x10692f3d0>
list(fibonacci_generator(10))
#
# [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
Calling fibonacci_generator()
directly returns a generator iterator object that allows you to iterate over the numbers in the Fibonacci sequence up to the index of your choice. However, you don’t need an iterator in your code. You need a list. A quick way to get that list is to wrap the iterator in a call to list()
, as you did in the final example.
This technique comes in handy when you’re working with functions that return iterators, and you want to construct a list object out of the items that the iterator yields. The list()
constructor will consume the iterator, build your list, and return it back to you.
Note
You can also use the literal syntax and the iterable unpacking operator (*
) as an alternative to the list()
constructor.
Here’s how:
[*fibonacci_generator(10)]
#
# [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
In this example, the iterable unpacking operator consumes the iterator, and the square brackets build the final list of numbers. However, this technique is less readable and explicit than using list()
.
As a side note, you’ll often find that built-in and third-party functions return iterators. Functions like reversed()
, enumerate()
, map()
, and filter()
are good examples of this practice. It’s less common to find functions that directly return list
objects, but the built-in sorted()
function is one example. It takes an iterable as an argument and returns a list of sorted items.
Building Lists With List Comprehensions
List comprehensions are one of the most distinctive features of Python. They’re quite popular in the Python community, so you’ll likely find them all around. List comprehensions allow you to quickly create and transform lists using a syntax that mimics a for
loop but in a single line of code.
The core syntax of list comprehensions looks something like this:
[expression(item) for item in iterable]
Every list comprehension needs at least three components:
expression()
is a Python expression that returns a concrete value, and most of the time, that value depends onitem
. Note that it doesn’t have to be a function.item
is the current object fromiterable
.iterable
can be any Python iterable object, such as a list, tuple, set, string, or generator.
The for
construct iterates over the items in iterable
, while expression(item)
provides the corresponding list item that results from running the comprehension.
To illustrate how list comprehensions allow you to create new lists out of existing iterables, say that you want to construct a list with the square values of the first ten integer numbers. In this case, you can write the following comprehension:
[number ** 2 for number in range(1, 11)]
#
# [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
In this example, you use range()
to get the first ten integer numbers. The comprehension iterates over them while computing the square and building the new list. This example is just a quick sample of what you can do with a list comprehension.
Note
To dive deeper into list comprehensions and how to use them, check out When to Use a List Comprehension in Python.
In general, you’ll use a list comprehension when you need to create a list of transformed values out of an existing iterable. Comprehensions are a great tool that you need to master as a Python developer. They’re optimized for performance and are quick to write.