Finding Stories in Spreadsheets
Finding Stories in Spreadsheets
Recipes for interviewing data - and getting answers
About the Book
One spreadsheet can tell many stories. You just have to know the right questions to ask.
Based on a decade of training journalists and working with news organisations on data-driven stories, Finding Stories In Spreadsheets outlines the techniques for asking the right questions of data using tools like Excel and Google spreadsheets.
These aren't just questions about numbers: you'll find out how spreadsheet techniques can help you find the 'needle in the haystack' in text data. You'll learn how to clean up and modify your data so that you can ask it different questions, or get it ready for maps or charts, how to create new data from raw materials, and how to combine datasets to look for connections and trends.
With regular examples from journalism and real life data to work with, Finding Stories In Spreadsheets is *full* of those questions, in the language that spreadsheets understand.
Stories about change, stories in context: basic calculations
- Cell references
- Calculating a change
- Calculating a proportion
- Ratios: calculating a proportion as ‘1 in 10’
- Combining both: calculating what proportion a change is
Saving time to hit a deadline: repeating and fixing a calculation across cells
- Shortcut: repeating a calculation down hundreds of cells with one double-click
- What if I want to fix the cell reference so it doesn’t change when pasted?
- The last chapter’s story: are there more drunk and disorderly arrests?
How much did it cost? How many people were affected? The first function: adding a series of cells with
- If functions are recipes, arguments are the ingredients
- When there’s more than one ingredient: commas and semicolons
Who’s top, who’s bottom?
MIN, and sorting
- MAX and MIN
- The last chapter’s story: drunk and disorderly arrest totals
Detour: getting to know the spreadsheet - useful shortcuts and tips to avoid mistakes
- Keyboard shortcuts to explore your data quickly
- Changing your data: remove empty rows before the headings
Hitting the deadline: understanding and formatting the data - number or text
Best sellers and averages:
- Calculating an average: AVERAGE, MEDIAN or MODE?
- Man made or natural?
How many payments? How many people? Counting, not adding up:
- The story is what’s missing: COUNTBLANK
- The last chapter’s story: political donations
Only count if… setting criteria for a formula:
- Counting something specific
- Looking for cells containing words within sentences: the wildcards
- Trial and error: the single-cell test
- Counting against combined criteria: COUNTIFS
- The last chapter’s story: missing donations data?
If… continued: setting criteria for a sum:
- The last story: how many donations fit the bill?
Putting the story into context, or looking from a fresh angle: merging data from different tables using
- Dry run: two small tables on the same sheet
- Using VLOOKUP on data in different sheets
- Those pesky #N/A results
- The last chapter’s story: what proportion of donations came from small donors?
My data is dirty! Basic cleaning using
- Those pesky spaces
Getting rid of ‘non printing’ characters:
- And or ampersand? Substituting particular words or characters
- The last chapter’s story: baby name trends
Detour: generating consecutive numbers or dates
- Other number sequences
- Text sequences: days and months
- Getting more control over your ranges - the Fill Series option
Using more than one function at a time: nested functions
- Nesting functions
Generating categories and other extra data:
- Testing more than one thing - nested IF
- Hello operators: comparing beyond ‘greater than’ or ‘less than’
- Testing text: combining IF with other functions
- The last chapter’s story: simplifying names to make them consistent with another dataset
Detour: testing whether something is TRUE or FALSE
- Logical tests with text
- Adding up TRUE and FALSE
- Functions which return logical results
Finding errors or missing data - and testing data types:
- Functions for testing data types
- Functions that look for errors, or types of errors
ISfunctions in practice: an error-checking column
- The last chapter’s story: converting restaurant ratings into categories
Testing two things at once:
- Finding outliers at the top or bottom: OR
- Finding one of a series of possible text values: OR
- Finding numbers in the middle, or in a particular range: AND
- Applying criteria across multiple columns
IFto avoid multiple
- Making multiple negative tests
- The last chapter’s story: classifying non-rated hygiene reports
What day did that date fall on? Which year was the worst? Extracting days, months and years from full dates
- Extracting dates, months and years: DAY, MONTH and YEAR
- Extracting days and months as words or years as ‘66, ‘94 etc: TEXT
- Using the Format Cells ‘Custom’ option to do the same thing to existing dates
- Hours and minutes: HOUR, MINUTE, SECOND and TEXT again
- When things don’t go as you expect them to: dealing with errors in date functions
- Finding the story: which outlets have consistently bad scores?
How old is someone? Ages and using
- Breaking down the problem
- Calculating the years
- Checking whether a birthday comes before or after a date
- Making an adjustment based on the results
TODAYto calculate an age against today’s date
- Making it easy to understand: breaking the formula back up
- Other ways of calculating ages: the unsupported DATEDIF function
- Watching out for leap years in other calculations
- Finding the story: what years and months are worst for hygiene inspections?
Grabbing or checking the first, middle or last part of a piece of information:
- Grabbing characters from the beginning: LEFT
- Grabbing characters from the end: RIGHT
- Grabbing characters from the middle: MID
- What if the starting position or number of characters depends? Introducing LEN
- What if the starting position or number of characters depends? Part two: SEARCH and FIND
- Finding the story: how old are Guantanamo prisoners?
Case study: When you get data in sentences: using
SEARCHand error handling to extract numbers from phrases
- Break down the steps
Identify where the years/months are detailed: using
- Extract the number of years/months (and correct for problems)
- Handling an unnecessary space
- Converting to a common measure
- Manual cleaning: identifying unusual words
- Adding a ‘checking’ formulae
- Key points
Putting names, addresses and other data back together:
&and adding special characters with
The alternative to
- Tell the story: finding special characters
- The alternative to
More data cleaning: formatting text or numbers consistently with
Rounding and formatting numbers:
- Showing figures as millions or billions without all the zeroes
- Rounding and formatting numbers:
Changing rows into columns, and vice versa:
TRANSPOSEfunction in Excel - for when you need data to always be transposed
TRANSPOSEfunction in Google Sheets - no need for keyboard shortcuts
- The Paste Special option: the one-off transpose
Repeating calculations across multiple cells or to create the ingredients of a single function: array formulae
- Arrays in practice: back to the drunk and disorderly data
- Changing or extending an array formula
- Multiple calculations with one result: using an array formula in a single cell
- Generating your own arrays
- Array constants used in a formula
- The last chapter’s story: when’s the worst time to turn up at hospital?
- Detour: An introduction to Google Sheets - an always-connected spreadsheet tool
- Make sure the settings are for your country
Grabbing data from elsewhere -
Pulling data from another sheet:
Grabbing data from online CSVs and TXT files:
Grabbing data from webpage tables and lists:
Grabbing data from RSS feeds:
Grabbing data from an XML document - or a HTML webpage:
IMPORTXMLto grab data from HTML webpages
- Grabbing links and other values that are not in visible text
- Pulling data from another sheet:
Dealing with data in another language:
Detecting the language:
DETECTLANGUAGEas part of
- False friends and cognates
- Tip: translating a term to generate search URLs in other languages
IMPORTExercises - tips
- Detecting the language:
Converting currency or using stock prices:
Converting currency with
Grabbing stock values with
- Converting currency with
Publishing live data in a live chart
Exercise: grabbing and visualising live data with
IMPORTHTMLand live charts
Comparing change visually by generating sparkline charts for every row:
- Customising how the sparkline appears: bar charts
- Keeping it relative: specifying minimum and maximum scale
Last chapter exercise: grabbing and visualising live data with
IMPORTHTMLand live charts
- Writing a
Asking questions (or allowing users to), SQL-style:
Forming the question:
More complex clauses:
- Writing queries with multiple or alternative criteria
- Generating ‘hackable’ URLs which allow users to see the data their own way
- Using a form to allow users to generate their own results pages
QUERYbeing used in code
- Forming the question:
Adding some randomness: spreading out locations randomly using
RAND: Give me a number between 1 and 0
RANDBETWEEN: Give me a number between whatever I say!
- Exercise: generate random placemarks on a map - within reason
Is this value ranked high or low? What value is 3rd?
Finding values at a particular rank:
- Using the
What percentile is this at or above?
- Percentile functions
What percent of values are smaller?
What value is at the nth percentile?
- Exercise: using both sets of functions with marathon race times
Classifying data into top, middle and bottom quarters:
- Applying quartile values to classify data into four quarters
- Using the
Cross referencing and advanced cell references: naming cells and using
- Naming cells
- Cross-referencing cells based on values in other cells
Working out which index to grab:
- Exercise: Finding where schoolchildren go outside their area
Getting statistical: correlation with
CORRELand other ways of testing data
- How strong is the relationship between two columns of numbers?
- Once you have a result
- Try it out
The final chapter: next steps
- What else can Excel do? Add-ins, templates and VBA
- Tell me your problems
The Leanpub 45-day 100% Happiness Guarantee
Within 45 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
See full terms
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers), EPUB (for phones and tablets) and MOBI (for Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
El Manual del ManagerKeyvan Akbary, Félix López, and Álvaro Salazar
¿Has deseado alguna vez el haber tenido una buena introducción al rol del Engineering Manager? En este libro aprenderás lo necesario para ejercer el rol de una manera efectiva: Expectativas y Responsabilidades del Rol, 1-1s, Ayudar a Crecer, Objetivos, Planes de Carrera, Cultura, Feedback, Contratación, Cultura de Producto y mucho más.
Functional Design and ArchitectureAlexander Granin
Software Design in Functional Programming, Design Patterns and Practices, Methodologies and Application Architectures. How to build real software in Haskell with less efforts and low risks. The first complete source of knowledge.
Ansible for KubernetesJeff Geerling
Ansible is a powerful infrastructure automation tool. Kubernetes is a powerful application deployment platform. Learn how to use these tools to automate massively-scalable, highly-available infrastructure.
Ansible for DevOpsJeff Geerling
Ansible is a simple, but powerful, server and configuration management tool. Learn to use Ansible effectively, whether you manage one server—or thousands.
Practical FP in Scala: A hands-on approachGabriel Volpe
A practical book aimed for those familiar with functional programming in Scala who are yet not confident about architecting an application from scratch.
Together, we will develop a purely functional application using the best libraries in the Cats ecosystem, while learning about design patterns and best practices.
Tame your Work FlowSteve Tendon and Daniel Doiron
Do you need a high performance enterprise governance approach improving management, execution and delivery while dealing with multiple projects/products, events, stakeholders and teams? Giving you better bottom line results, faster time to market, less work, better predictability, happier employees, and delighted clients? Then learn about TameFlow!
C++ Best PracticesJason Turner
Level up your C++, get the tools working for you, eliminate common problems, and move on to more exciting things!
Cloud StrategyGregor Hohpe
“Strategy is the difference between making a wish and making it come true.” A successful migration to the cloud shouldn’t be driven by wishes, but guided by a sound strategy, frameworks, and decision models. This book tells you how—without becoming superficial nor getting lost in technology and product details.
Machine Learning EngineeringAndriy Burkov
"If you intend to use machine learning to solve business problems at scale, I'm delighted you got your hands on this book."
—Cassie Kozyrkov, Chief Decision Scientist at Google
"Foundational work about the reality of building machine learning models in production."
—Karolis Urbonas, Head of Machine Learning and Science at Amazon
Composing SoftwareEric Elliott
All software design is composition: the act of breaking complex problems down into smaller problems and composing those solutions. Most developers have a limited understanding of compositional techniques. It's time for that to change.
11 BooksThe Quality Software Bundle is for managers, would-be managers, and any of us who find themselves being managed and confused. This comprehensive bundle covers the entire span of software development approaches, from hacking through waterfall, cascade, prototyping, Iterative enhancement, reusable code, off-the-shelf, to Agile teams. The bundle...
The Node.js Bundle
3 BooksThis bundle combines three bestselling Leanpub Node.js books into a package that gives you everything you need to get started with developing Node.js applications at an unbeatable price.
The Tester's Library
8 BooksThe Tester's Library consists of eight five-star books that every software tester should read and re-read. As bound books, this collection would cost over $200. Even as e-books, their price would exceed $80, but in this bundle, their cost is only $49.99. Here are the books, and why they should be in your library: Perfect Software and Other...
11 BooksIn this bundle, you will find 10 different agile books. They are about different aspects of being agile. - finding a job - doing coding dojo's - Retrospectives - Personal kanban - a non-typical coaching book and even a book that gives you an insight in the lives of some agile people.
WTFlop 6M + HU - Beta Bundle
Marionette.js A to Z
Complete Scala Bundle
3 BooksScala is a general-purpose programming language and it's getting extremely popular these days. Some say that learning Scala could be a challenging task. My experience, however, suggests that this is actually a myth that has very little to do with reality. With the right approach, learning Scala can be easy, fun and rewarding.The first book from...
Build A Better Backbone App
3 BooksThe best way to learn new development skills is through experience, but that takes time you don't have.Get the best of both worlds with this bundle: you'll learn how to produce modern web applications by learning from experienced developers like Derick Bailey and David Sulc. BackboneJS is one of the favorite tools on the web today, but it...
People Skills—Soft but Difficult
7 BooksPerhaps you've been told that "lack of people skills" has been holding you back. No wonder: you may have had hundreds of hours of technical training, but little or no "people skills" guidance.You've heard it said that people skills are "soft," whereas technical skills are "hard." For you, though, technical skills are "easy," but people skills...
SurviveJS - Webpack + React
2 BooksGet both SurviveJS - Webpack and SurviveJS - React for a single price!