Self-reported life satisfaction

What you should know about this indicator
- The Cantril ladder asks respondents to think of a ladder, with the best possible life for them being a 10 and the worst possible life being a 0. They are then asked to rate their own current lives on that 0 to 10 scale.
- The rankings are calculated by the World Happiness Report based on nationally representative samples collected by the Gallup World Poll.
- The score is the average of the three-year survey period, i.e. the year 2025 shows the average of the 2023-2025 survey data.
- The number of people and countries surveyed varies year to year, but typically more than 100,000 people in over 140 countries participate in the Gallup World Poll each year.
- The rankings are based entirely on the survey scores, which are weighted by Gallup to make the estimates representative.
Related research and writing
More Data on Happiness & Life Satisfaction
Sources and processing
This data is based on the following sources
How we process data at Our World in Data
All data and visualizations on Our World in Data rely on data sourced from one or several original data providers. Preparing this original data involves several processing steps. Depending on the data, this can include standardizing country names and world region definitions, converting units, calculating derived indicators such as per capita measures, as well as adding or adapting metadata such as the name or the description given to an indicator.
At the link below you can find a detailed description of the structure of our data pipeline, including links to all the code used to prepare data across Our World in Data.
Notes on our processing step for this indicator
We calculated the average of regions by taking a population-weighted average over all countries within that region.
Reuse this work
Citations
How to cite this page
To cite this page overall, including any descriptions, FAQs or explanations of the data authored by Our World in Data, please use the following citation:
“Data Page: Self-reported life satisfaction”, part of the following publication: Esteban Ortiz-Ospina, Tuna Acisu, and Max Roser (2017) - “Happiness and Life Satisfaction”. Data adapted from Wellbeing Research Centre. Retrieved from https://archive.ourworldindata.org/20260319-160338/grapher/happiness-cantril-ladder.html [online resource] (archived on March 19, 2026).How to cite this data
In-line citationIf you have limited space (e.g. in data visualizations), you can use this abbreviated in-line citation:
Wellbeing Research Centre (2026) – with major processing by Our World in DataFull citation
Wellbeing Research Centre (2026) – with major processing by Our World in Data. “Self-reported life satisfaction” [dataset]. Wellbeing Research Centre, “World Happiness Report 2026” [original data]. Retrieved April 1, 2026 from https://archive.ourworldindata.org/20260319-160338/grapher/happiness-cantril-ladder.html (archived on March 19, 2026).Download
Quick download
Download the data shown in this chart as a ZIP file containing a CSV file, metadata in JSON format, and a README. The CSV file can be opened in Excel, Google Sheets, and other data analysis tools.
Data API
Use these URLs to programmatically access this chart's data and configure your requests with the options below. Our documentation provides more information on how to use the API, and you can find a few code examples below.
Data URL (CSV format)
https://ourworldindata.org/grapher/happiness-cantril-ladder.csv?v=1&csvType=full&useColumnShortNames=falseMetadata URL (JSON format)
https://ourworldindata.org/grapher/happiness-cantril-ladder.metadata.json?v=1&csvType=full&useColumnShortNames=falseExcel / Google Sheets
=IMPORTDATA("https://ourworldindata.org/grapher/happiness-cantril-ladder.csv?v=1&csvType=full&useColumnShortNames=false")Python with Pandas
import pandas as pd
import requests
# Fetch the data.
df = pd.read_csv("https://ourworldindata.org/grapher/happiness-cantril-ladder.csv?v=1&csvType=full&useColumnShortNames=false", storage_options = {'User-Agent': 'Our World In Data data fetch/1.0'})
# Fetch the metadata
metadata = requests.get("https://ourworldindata.org/grapher/happiness-cantril-ladder.metadata.json?v=1&csvType=full&useColumnShortNames=false").json()R
library(jsonlite)
# Fetch the data
df <- read.csv("https://ourworldindata.org/grapher/happiness-cantril-ladder.csv?v=1&csvType=full&useColumnShortNames=false")
# Fetch the metadata
metadata <- fromJSON("https://ourworldindata.org/grapher/happiness-cantril-ladder.metadata.json?v=1&csvType=full&useColumnShortNames=false")Stata
import delimited "https://ourworldindata.org/grapher/happiness-cantril-ladder.csv?v=1&csvType=full&useColumnShortNames=false", encoding("utf-8") clear




