Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Newsletter Hub
Free Learning
Arrow right icon
timer SALE ENDS IN
0 Days
:
00 Hours
:
00 Minutes
:
00 Seconds
Arrow up icon
GO TO TOP
Polars Cookbook

You're reading from   Polars Cookbook Over 60 practical recipes to transform, manipulate, and analyze your data using Python Polars 1.x

Arrow left icon
Product type Paperback
Published in Aug 2024
Publisher Packt
ISBN-13 9781805121152
Length 394 pages
Edition 1st Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Yuki Kakegawa Yuki Kakegawa
Author Profile Icon Yuki Kakegawa
Yuki Kakegawa
Arrow right icon
View More author details
Toc

Table of Contents (15) Chapters Close

Preface 1. Chapter 1: Getting Started with Python Polars FREE CHAPTER 2. Chapter 2: Reading and Writing Files 3. Chapter 3: An Introduction to Data Analysis in Python Polars 4. Chapter 4: Data Transformation Techniques 5. Chapter 5: Handling Missing Data 6. Chapter 6: Performing String Manipulations 7. Chapter 7: Working with Nested Data Structures 8. Chapter 8: Reshaping and Tidying Data 9. Chapter 9: Time Series Analysis 10. Chapter 10: Interoperability with Other Python Libraries 11. Chapter 11: Working with Common Cloud Data Sources 12. Chapter 12: Testing and Debugging in Polars 13. Index 14. Other Books You May Enjoy

Turning columns into rows

Unpivoting is a common operation done when reshaping or tidying your data. It helps turn and compact columns into rows. In other words, the unpivot operation converts your data from a wide format to a long format. This operation is also known as unpivot.

Both wide format and long format have their use cases. Some client tools prefer wide format while some prefer long format.

In this recipe, we’ll cover how to turn columns into rows using the unpivot operation.

How to do it...

Here’s how to turn columns into rows:

  1. Use the .unpivot() method to turn columns into rows:
    long_df = df.unpivot(
        index='academic_year',
            on=[
                'students',
                'us_students',
                'undergraduate',
                'graduate',
                'non_degree',
                'opt'
            ],
        variable_name='student_type',
        value_name='count'
    )
    long_df.head()

    The preceding code will return the following output:

Figure 8.2 – The DataFrame in a long format

Figure 8.2 – The DataFrame in a long format

  1. Let’s check the student_type column to make sure it contains the values we expect:
    long_df.select('student_type').unique()

    The preceding code will return the following output:

Figure 8.3 – Unique values in the student_type column

Figure 8.3 – Unique values in the student_type column

  1. Utilize selectors in Polars to select columns at once for the same unpivot operation. This time, we won’t change the variable and value names:
    df.unpivot(
        index='academic_year',
        on=cs.numeric()
    ).head()

    The preceding code will return the following output:

Figure 8.4 – The DataFrame in a long format without renaming new columns

Figure 8.4 – The DataFrame in a long format without renaming new columns

  1. Apply the unpivot operation in a LazyFrame.

    Let’s say you had a LazyFrame instead of a DataFrame:

    lf = df.lazy()

    You can still apply the unpivot operation in a LazyFrame:

    (
        lf
        .unpivot(
            index='academic_year',
            on=cs.numeric(),
            variable_name='student_type',
            value_name='count'
        )
        .collect()
        .head()
    )

The preceding code will return the same output as Figure 8.4.

How it works...

Using the .unpivot() method is straightforward. You specify the columns to keep and the columns that get turned into rows.

In step 3, we didn’t specify the variable and value names. In that case, Polars automatically names those columns variable and value, respectively.

Also, as you know, many DataFrame methods are available in a LazyFrame; the .unpivot() method is one of them, which is great news.

See also

Feel free to refer to these resources to learn more about turning columns into rows:

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image