Skip to content
Exploring the History of Lego
  • AI Chat
  • Code
  • Report
  • 1. Introduction

    Everyone loves Lego (unless you ever stepped on one). Did you know by the way that "Lego" was derived from the Danish phrase leg godt, which means "play well"? Unless you speak Danish, probably not.

    In this project, we will analyze a fascinating dataset on every single Lego block that has ever been built!

    lego

    # Nothing to do here
    Hidden output

    2. Reading Data

    A comprehensive database of lego blocks is provided by Rebrickable. The data is available as csv files and the schema is shown below.

    schema

    Let us start by reading in the colors data to get a sense of the diversity of Lego sets!

    # Import pandas
    import pandas as pd
    
    # Read colors data
    colors = pd.read_csv('datasets/colors.csv')
    
    # Print the first few rows
    print(colors.head())

    3. Exploring Colors

    Now that we have read the colors data, we can start exploring it! Let us start by understanding the number of colors available.

    # How many distinct colors are available?
    num_colors = colors.rgb.size
    
    # Print num_colors
    print('Distinct colors available:', num_colors)

    4. Transparent Colors in Lego Sets

    The colors data has a column named is_trans that indicates whether a color is transparent or not. It would be interesting to explore the distribution of transparent vs. non-transparent colors.

    # colors_summary: Distribution of colors based on transparency
    colors_summary = colors.groupby('is_trans').count()
    print(colors_summary)

    5. Explore Lego Sets

    Another interesting dataset available in this database is the sets data. It contains a comprehensive list of sets over the years and the number of parts that each of these sets contained.

    sets_data

    Let us use this data to explore how the average number of parts in Lego sets has varied over the years.

    %matplotlib inline
    # Read sets data as `sets`
    sets = pd.read_csv('datasets/sets.csv')
    
    # Create a summary of average number of parts by year: `parts_by_year`
    parts_by_year = sets[['year', 'num_parts']].groupby('year').mean()
    
    # Plot trends in average number of parts by year
    parts_by_year.plot()
    

    6. Lego Themes Over Years

    Lego blocks ship under multiple themes. Let us try to get a sense of how the number of themes shipped has varied over the years.

    # themes_by_year: Number of themes shipped by year
    themes_by_year = sets.groupby('year')[['theme_id']].nunique()
    themes_by_year.head()

    7. Wrapping It All Up!

    Lego blocks offer an unlimited amount of fun across ages. We explored some interesting trends around colors, parts, and themes. Before we wrap up, let's take a closer look at the themes_by_year DataFrame you created in the previous step.

    # Get the number of unique themes released in 1999
    num_themes = themes_by_year.loc[1999,'theme_id']
    
    # Print the number of unique themes released in 1999
    print(num_themes)