Python Lists

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=1

Learn to store, access and manipulate data in lists: the first step towards efficiently working with huge amounts of data.

In [1]:
fmz = [1.65, 1.45, 1.76]
fmz


Out[1]:
[1.65, 1.45, 1.76]

In [2]:
fmz2 = [1, 3, 1.2, 'Hello']
fmz2


Out[2]:
[1, 3, 1.2, 'Hello']

In [3]:
fmz3= [[23,12],
       [99, 1]]
fmz3


Out[3]:
[[23, 12], [99, 1]]

2. Create a list

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=2

As opposed to int, bool etc, a list is a compound data type: you can group values together:
a = "is"
b = "nice"
my_list = ["my", "list", a, b]
After measuring the height of your family, you decide to collect some information on the house you're living in. The areas of the different parts of your house are stored in separate variables for now, as shown in the script.

Instructions

Create a list, areas, that contains the area of the hallway (hall), kitchen (kit), living room (liv), bedroom (bed) and bathroom (bath), in this order. Use the predefined variables.
Print areas with the print() function.

In [4]:
# area variables (in square meters)
hall = 11.25
kit = 18.0
liv = 20.0
bed = 10.75
bath = 9.50

# Create list areas
areas = [hall, kit, liv, bed, bath]


# Print areas
print(areas)


[11.25, 18.0, 20.0, 10.75, 9.5]

3. Create list with different types

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=3

A list can contain any Python type. Although it's not really common, a list can also contain a mix of Python types including strings, floats, booleans, etc.

The printout of the previous exercise wasn't really satisfying. It's just a list of numbers representing the areas, but you can't tell which area corresponds to which part of your house.

The code on the right is the start of a solution. For some of the areas, the name of the corresponding room is already placed in front. Pay attention here! "bathroom" is a string, while bath is a variable that represents the float 9.50 you specified earlier.

Instructions

Finish the line of code that creates the areas list such that the list first contains the name of each room as a string, and then its area. More specifically, add the strings "hallway", "kitchen" and "bedroom" at the appropriate locations.
Print areas again; is the printout more informative this time?

In [5]:
# area variables (in square meters)
hall = 11.25
kit = 18.0
liv = 20.0
bed = 10.75
bath = 9.50

# Adapt list areas
areas = ['hallway', hall, 'kitchen', kit, "living room", liv, 'bedroom', bed, "bathroom", bath]

# Print areas
print(areas)


['hallway', 11.25, 'kitchen', 18.0, 'living room', 20.0, 'bedroom', 10.75, 'bathroom', 9.5]

4. Select the valid list

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=4

A list can contain any Python type. But a list itself is also a Python type. That means that a list can also contain a list! Python is getting funkier by the minute, but fear not, just remember the list syntax:
my_list = [el1, el2, el3]
Can you tell which ones of the following lines of Python code are valid ways to build a list?
A. [1, 3, 4, 2] B. [[1, 2, 3], [4, 5, 7]] C. [1 + 2, "a" * 5, 3]

Possible Answers

A, B and C
B
B and C
C

In [6]:
[1, 3, 4, 2]


Out[6]:
[1, 3, 4, 2]

In [7]:
[[1, 2, 3], [4, 5, 7]]


Out[7]:
[[1, 2, 3], [4, 5, 7]]

In [8]:
[1 + 2, "a" * 5, 3]


Out[8]:
[3, 'aaaaa', 3]

5. List of lists

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=5

As a data scientist, you'll often be dealing with a lot of data, and it will make sense to group some of this data.

Instead of creating a flat list containing strings and floats, representing the names and areas of the rooms in your house, you can create a list of lists. The script on the right can already give you an idea.

Don't get confused here: "hallway" is a string, while hall is a variable that represents the float 11.25 you specified earlier.

Instructions

Finish the list of lists so that it also contains the bedroom and bathroom data. Make sure you enter these in order!
Print out house; does this way of structuring your data make more sense?
Print out the type of house. Are you still dealing with a list?

In [9]:
# area variables (in square meters)
hall = 11.25
kit = 18.0
liv = 20.0
bed = 10.75
bath = 9.50

# house information as list of lists
house = [["hallway", hall],
         ["kitchen", kit],
         ["living room", liv],
         ["bedroom", bed],
         ["bathroom", bath]]

# Print out house
print(house)

# Print out the type of house
print(type(house))


[['hallway', 11.25], ['kitchen', 18.0], ['living room', 20.0], ['bedroom', 10.75], ['bathroom', 9.5]]
<class 'list'>

In [10]:
fam = ['liz', 1.73, 'emma', 1.68, 'mom', 1.71, 'dad', 1.89]
fam


Out[10]:
['liz', 1.73, 'emma', 1.68, 'mom', 1.71, 'dad', 1.89]

In [11]:
fam[3]


Out[11]:
1.68

In [12]:
fam[6]


Out[12]:
'dad'

In [13]:
fam[-1]


Out[13]:
1.89

In [14]:
fam[-2]


Out[14]:
'dad'

In [15]:
fam[3:5]


Out[15]:
[1.68, 'mom']

In [16]:
fam[1:4]


Out[16]:
[1.73, 'emma', 1.68]

In [17]:
fam[:4]


Out[17]:
['liz', 1.73, 'emma', 1.68]

7. Subset and conquer

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=7

Subsetting Python lists is a piece of cake. Take the code sample below, which creates a list x and then selects "b" from it. Remember that this is the second element, so it has index 1. You can also use negative indexing.
x = list["a", "b", "c", "d"]
x[1]
x[-3] # same result!

Remember the areas list from before, containing both strings and floats? Its definition is already in the script. Can you add the correct code to do some Python subsetting?

Instructions

Print out the second element from the areas list, so 11.25.
Subset and print out the last element of areas, being 9.50. Using a negative index makes sense here!
Select the number representing the area of the living room and print it out.

In [18]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, 
         "bedroom", 10.75, "bathroom", 9.50]

# Print out second element from areas
print(areas[2])

# Print out last element from areas
print(areas[-1])

# Print out the area of the living room
print(areas[5])


kitchen
9.5
20.0

In [19]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, "bedroom", 10.75, "bathroom", 9.50]

# Print out second element from areas
print(areas[1])

# Print out last element from areas
print(areas[-1])

# Print out the area of the living room
print(areas[5])


11.25
9.5
20.0

8. Subset and calculate

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=8

After you've extracted values from a list, you can use them to perform additional calculations. Take this example, where the second and fourth element of a list x are extracted. The strings that result are pasted together using the + operator:
x = ["a", "b", "c", "d"]
print(x[1] + x[3])

Instructions

Using a combination of list subsetting and variable assignment, create a new variable, eat_sleep_area, that contains the sum of the area of the kitchen and the area of the bedroom.
Print this new variable eat_sleep_area.

In [20]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, 
         "bedroom", 10.75, "bathroom", 9.50]

# Sum of kitchen and bedroom area: eat_sleep_area
eat_sleep_area = areas[3] + areas[-3]

# Print the variable eat_sleep_area
print(eat_sleep_area)


28.75

9. Slicing and dicing

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=9

Selecting single values from a list is just one part of the story. It's also possible to slice your list, which means selecting multiple elements from your list. Use the following syntax:
my_list[start:end]
The start index will be included, while the end index is not.

The code sample below shows an example. A list with "b" and "c", corresponding to indexes 1 and 2, are selected from a list x:
x = ["a", "b", "c", "d"]
x[1:3]
The elements with index 1 and 2 are included, while the element with index 3 is not.

Instructions

Use slicing to create a list, downstairs, that contains the first 6 elements of areas.
Do a similar thing to create a new variable, upstairs, that contains the last 4 elements of areas.
Print both downstairs and upstairs using print().

In [21]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, 
         "bedroom", 10.75, "bathroom", 9.50]

# Use slicing to create downstairs
downstairs = areas[0:6]

# Use slicing to create upstairs
upstairs = areas[6:10]

# Print out downstairs and upstairs
print(downstairs)
print(upstairs)


['hallway', 11.25, 'kitchen', 18.0, 'living room', 20.0]
['bedroom', 10.75, 'bathroom', 9.5]

10. Slicing and dicing (2)

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=10

In the video, Filip only discussed the syntax where you specify both where to begin and end the slice of your list:
my_list[begin:end]

However, it's also possible not to specify these indexes. If you don't specify the begin index, Python figures out that you want to start your slice at the beginning of your list. If you don't specify the end index, the slice will go all the way to the last element of your list. To experiment with this, try the following commands in the IPython Shell:
x = ["a", "b", "c", "d"]
x[:2]
x[2:]
x[:]

Instructions

Use slicing to create the lists downstairs and upstairs again, but this time without using indexes if it's not necessary. Remember downstairs is the first 6 elements of areas and upstairs is the last 4 elements of areas.

In [22]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, 
         "bedroom", 10.75, "bathroom", 9.50]

# Use slicing to create downstairs
downstairs = areas[:6]

# Use slicing to create upstairs
upstairs = areas[-4:]

# Print out downstairs and upstairs
print(downstairs)
print(upstairs)


['hallway', 11.25, 'kitchen', 18.0, 'living room', 20.0]
['bedroom', 10.75, 'bathroom', 9.5]

11. Subsetting lists of lists

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=11

You saw before that a Python list can contain practically anything; even other lists! To subset lists of lists, you can use the same technique as before: square brackets. Try out the commands in the following code sample in the IPython Shell:
x = [["a", "b", "c"],
 ["d", "e", "f"],
 ["g", "h", "i"]]
x[2][0]
x[2][:2]
x[2] results in a list, that you can subset again by adding additional square brackets.

What will house[-1][1] return? house, the list of lists that you created before, is already defined for you in the workspace. You can experiment with it in the IPython Shell.

Possible Answers

A float: the kitchen area
A string: "kitchen"
A float: the bathroom area
A string: "bathroom"

In [23]:
house[-1]


Out[23]:
['bathroom', 9.5]

In [24]:
house[-1][1]


Out[24]:
9.5

In [25]:
fam = ['liz', 1.73, 'emma', 1.68, 'mom', 1.71, 'dad', 1.89]
fam


Out[25]:
['liz', 1.73, 'emma', 1.68, 'mom', 1.71, 'dad', 1.89]

In [26]:
fam[7] = 1.86
fam


Out[26]:
['liz', 1.73, 'emma', 1.68, 'mom', 1.71, 'dad', 1.86]

In [27]:
fam[0:2] = ['lisa', 1.74]
fam


Out[27]:
['lisa', 1.74, 'emma', 1.68, 'mom', 1.71, 'dad', 1.86]

In [28]:
fam + ['me', 1.79]


Out[28]:
['lisa', 1.74, 'emma', 1.68, 'mom', 1.71, 'dad', 1.86, 'me', 1.79]

In [29]:
fam_ext = fam + ['me', 1.79]
fam_ext


Out[29]:
['lisa', 1.74, 'emma', 1.68, 'mom', 1.71, 'dad', 1.86, 'me', 1.79]

In [30]:
del(fam[2])
fam


Out[30]:
['lisa', 1.74, 1.68, 'mom', 1.71, 'dad', 1.86]

In [31]:
del(fam[2])
fam


Out[31]:
['lisa', 1.74, 'mom', 1.71, 'dad', 1.86]

In [32]:
x = ['a', 'b', 'c']
x


Out[32]:
['a', 'b', 'c']

In [33]:
y = x
y[1] = 'z'
y


Out[33]:
['a', 'z', 'c']

In [34]:
x


Out[34]:
['a', 'z', 'c']

In [35]:
z = list(x)
z = x[:]
z[1] = 'm'
z


Out[35]:
['a', 'm', 'c']

In [36]:
x


Out[36]:
['a', 'z', 'c']

13. Replace list elements

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=13

Replacing list elements is pretty easy. Simply subset the list and assign new values to the subset. You can select single elements or you can change entire list slices at once.

Use the IPython Shell to experiment with the commands below. Can you tell what's happening and why?
x = ["a", "b", "c", "d"]
x[1] = "r"
x[2:] = ["s", "t"]

For this and the following exercises, you'll continue working on the areas list that contains the names and areas of different rooms in a house.

Instructions

You did a miscalculation when determining the area of the bathroom; it's 10.50 square meters instead of 9.50. Can you make the changes?
Make the areas list more trendy! Change "living room" to "chill zone".

In [37]:
# Create the areas list
areas = ["hallway", 11.25, "kitchen", 18.0, "living room", 20.0, "bedroom", 10.75, "bathroom", 9.50]

# Correct the bathroom area
areas[-1] = 10.50

# Change "living room" to "chill zone"
areas[4] = 'chill zone'

areas


Out[37]:
['hallway',
 11.25,
 'kitchen',
 18.0,
 'chill zone',
 20.0,
 'bedroom',
 10.75,
 'bathroom',
 10.5]

14. Extend a list

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=14

If you can change elements in a list, you sure want to be able to add elements to it, right? You can use the + operator:
x = ["a", "b", "c", "d"]
y = x + ["e", "f"]

You just won the lottery, awesome! You decide to build a poolhouse and a garage. Can you add the information to the areas list?

Instructions

Use the + operator to paste the list ["poolhouse", 24.5] to the end of the areas list. Store the resulting list as areas_1.
Further extend areas_1 by adding data on your garage. Add the string "garage" and float 15.45. Name the resulting list areas_2.

In [38]:
x = ["a", "b", "c", "d"]
y = x + ["e", "f"]
y


Out[38]:
['a', 'b', 'c', 'd', 'e', 'f']

In [39]:
# Create the areas list and make some changes
areas = ["hallway", 11.25, "kitchen", 18.0, "chill zone", 20.0,
         "bedroom", 10.75, "bathroom", 10.50]

# Add poolhouse data to areas, new list is areas_1
areas_1 = areas + ["poolhouse", 24.5]

# Add garage data to areas_1, new list is areas_2
areas_2 = areas_1 + ["garage", 15.45]

areas_2


Out[39]:
['hallway',
 11.25,
 'kitchen',
 18.0,
 'chill zone',
 20.0,
 'bedroom',
 10.75,
 'bathroom',
 10.5,
 'poolhouse',
 24.5,
 'garage',
 15.45]

15. Delete list elements

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=15

Finally, you can also remove elements from your list. You can do this with the del statement:
x = ["a", "b", "c", "d"]
del(x[1])

Pay attention here: as soon as you remove an element from a list, the indexes of the elements that come after the deleted element all change!

The updated and extended version of areas that you've built in the previous exercises is coded below. You can copy and paste this into the IPython Shell to play around with the result.
areas = ["hallway", 11.25, "kitchen", 18.0,
    "chill zone", 20.0, "bedroom", 10.75,
     "bathroom", 10.50, "poolhouse", 24.5,
     "garage", 15.45]

There was a mistake! The amount you won with the lottery is not that big after all and it looks like the poolhouse isn't going to happen. You decide to remove the corresponding string and float from the areas list.

The ; sign is used to place commands on the same line. The following two code chunks are equivalent:

Same line

command1; command2

Separate lines

command1
command2

Which of the code chunks will do the job for us?

Possible Answers

del(areas[10]); del(areas[11])
del(areas[10:11])
del(areas[-4:-2])
del(areas[-3]); del(areas[-4])

In [40]:
x = ["a", "b", "c", "d"]
del(x[1])
x


Out[40]:
['a', 'c', 'd']

In [41]:
areas = ["hallway", 11.25, "kitchen", 18.0,
        "chill zone", 20.0, "bedroom", 10.75,
         "bathroom", 10.50, "poolhouse", 24.5,
         "garage", 15.45]
del(areas[-3])
areas


Out[41]:
['hallway',
 11.25,
 'kitchen',
 18.0,
 'chill zone',
 20.0,
 'bedroom',
 10.75,
 'bathroom',
 10.5,
 'poolhouse',
 'garage',
 15.45]

16. Inner workings of lists

https://campus.datacamp.com/courses/intro-to-python-for-data-science/chapter-2-python-lists?ex=16

At the end of the video, Filip explained how Python lists work behind the scenes. In this exercise you'll get some hands-on experience with this.

The Python code in the script already creates a list with the name areas and a copy named areas_copy. Next, the first element in the areas_copy list is changed and the areas list is printed out. If you hit Submit Answer you'll see that, although you've changed areas_copy, the change also takes effect in the areas list. That's because areas and areas_copy point to the same list.

If you want to prevent changes in areas_copy to also take effect in areas, you'll have to do a more explicit copy of the areas list. You can do this with list() or by using [:].

Watch out! list() and [:] might not copy properly if you put complex things in your lists.

Instructions

Change the second command, that creates the variable areas_copy, such that areas_copy is an explicit copy of areas
Now, changes made to areas_copy shouldn't affect areas. Hit Submit Answer to check this.

In [42]:
# Create list areas
areas = [11.25, 18.0, 20.0, 10.75, 9.50]

# Create areas_copy
areas_copy = areas

# Change areas_copy
areas_copy[0] = 5.0

# Print areas
print(areas)


[5.0, 18.0, 20.0, 10.75, 9.5]

In [43]:
# Create list areas
areas = [11.25, 18.0, 20.0, 10.75, 9.50]

# Create areas_copy
areas_copy = list(areas)
areas_copy = areas[:]

# Change areas_copy
areas_copy[0] = 5.0

# Print areas
print(areas)


[11.25, 18.0, 20.0, 10.75, 9.5]

In [ ]: