Tuesday Tip #9: Calculate scoring runs in basketball ๐Ÿ€


Hi Reader!

Before we get to today's tip, I have three big launch announcements:

1. My new course, Become a Regex Superhero, launches this Friday! Watch out for more info and a huge launch discount.

2. I recently launched location-based pricing. I'm offering a discount of up to 85% to residents of 160+ countries.

3. My pal Ben Collins just launched a new course, Beginner Apps Script, which lets you extend the functionality of Google Sheets (and other Google Apps). Ben is the best Sheets teacher I know and is offering 50% off during the launch! (FYI, this is an affiliate link, which means that I may earn a commission if you sign up using my link.)


๐Ÿ‘‰ Tip #9: Calculate basketball scoring runs

Are you watching March Madness? If so, hit reply and let me know how your bracket is doing ๐Ÿ˜‚

For those who don't know, March Madness is a US college basketball tournament. One term that you'll hear a lot during games is scoring runs.

For example, a team that's on a "12-point scoring run" has scored 12 points without the other team scoring any points.

So I was wondering: How could we calculate scoring runs using pandas? ๐Ÿผ

Let's find out!


Example scoring data

Let's pretend this was our scoring data. There's one row for each time a team scored points:

In this case, the largest scoring run was when A scored 9 points in a row.


Identify each scoring run

Now we need to figure out when each scoring run starts!

First, we use the shift() method to shift all of the teams down a row, and store those in a column called previous_team:

Then, we check if team is not equal to previous_team, and store the boolean result in a column called start_of_run:

Do you see how that works?

By checking whether a given team value is equal to the value in the previous row, we now know when each scoring run starts!

Finally, we use the cumsum() method to assign a run_id to each scoring run:

Wait, what just happened?

Any time you do math on a boolean column, True gets treated as 1 and False gets treated as 0. Thus by taking the cumulative sum of the start_of_run column, the run_id increments every time it reaches a True value. (Neat, right?)

Shout out to Josh Devlin's excellent blog post, Calculating Streaks in Pandas, for teaching me this exact approach!


List all scoring runs

Now that each run has been assigned an id, we use a groupby() to show the number of points scored by each team during each run:

That's it! Here's the code from today's tip, in case you want to play around with it.

How else could we analyze this data using pandas? ๐Ÿค”

Have an idea? Hit reply and let me know! ๐Ÿ’ก


If you enjoyed this week's tip, please forward it to a friend! Takes only a few seconds, and it really helps me out ๐Ÿ™

See you next Tuesday!

- Kevin

P.S. Six people predicted the Final Four correctlyโ€‹

Did someone awesome forward you this email? Sign up here to receive data science tips every week!

Learn Artificial Intelligence from Data School ๐Ÿค–

Join 25,000+ intelligent readers and receive AI tips every Tuesday!

Read more from Learn Artificial Intelligence from Data School ๐Ÿค–

Hi Reader, Last week, I encouraged you to experiment with different LLMs, since thereโ€™s no one model that is superior across all use cases. Specifically, I suggested you try using Chatbot Arena, which allows you to chat with multiple models at once. Itโ€™s completely free, but has two significant disadvantages: Your chats are not private and may be used for research. It lacks the feature-rich interface provided by other LLMs. Today, I want to offer you a better method for experimenting with...

Hi Reader, Over the past 50 tips, Iโ€™ve touched on many different topics: Python, Jupyter, pandas, ML, data visualization, and so on. Going forward, Iโ€™m planning to focus mostly on Artificial Intelligence. Iโ€™m announcing this so you know what to expect, and I know what to deliver! ๐Ÿ’Œ Iโ€™ll also try to make the tips shorter, so that they're easier to digest on-the-go. Finally, I plan to include an โ€œaction itemโ€ each week, so that you can practice what youโ€™re learning. I hope you like these...

Hi Reader, Next week, Iโ€™ll be offering a Black Friday sale on ALL of my courses. Iโ€™ll send you the details this Thursday! ๐Ÿšจ ๐Ÿ‘‰ Tip #50: What is a "method" in Python? In Python, a method is a function that can be used on an object because of the object's type. For example, if you create a Python list, the "append" method can be used on that list. All lists have an "append" method simply because they are lists: If you create a Python string, the "upper" method can be used on that string simply...