npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

usbabynames

v2.1.2

Published

Returns data about baby names used in the United States 1880-2021

Downloads

53

Readme

usBabyNames.js

NPM module: JS / SQLite: Historical database of United States baby names Source: Social Security card applications US births after 1879 / chatGPT National data: 1880-2023 State data: 1910-2023

NPM version Node.js Package

New!

2024-08-31 Added breakdown by state, 1910-2023. 6,504,161 records

2024-08-10 Added 115,604 name details including pronunciation / origin / usage / notes. Moved to proper ES6 exports. Also... access the DBs straight from JS

About

Built on the Social Security Administration baby names files, usBabyNames.js returns interesting historical data on baby name usage from 1880-2023

National Data: 1880-2023

  • 2,114,982 records
  • Name
  • Sex
  • Number of births that year
  • Rank for that year

State Data: 1910-2023

  • 6,504,161 records
  • Name
  • Sex
  • Number of births that year
  • Rank
  • State

Name Details

  • 115,263 records
  • Name
  • Sex
  • Pronunciation
  • Country of Origin
  • Meaning
  • Historical notes

Usage

  • Identify naming trends based on real data
  • See the top 10 names for a year
  • Track the popularity of a name over time
  • Sort by male vs. female name usage for specific name
  • See the number of children given the name "Jonathan" in 1975
  • Calculate the percentage of childen named "Jonathan" since 1975
  • Whatever you want, really. Slice and dice however you like

Install

npm install usbabynames --save

Historical Name Data Usage

const getByName = async () => {
	const { getByName } = await import('../lib/usBabyNames.mjs');
	const theNames = await getByName('debbie');
	console.log('theNames', theNames);
};

getByName();

Name Details Usage

const getDetailed = async () => {
	const usBabyNames = await import('../lib/usBabyNames.mjs');
	const theDetails = await usBabyNames.getDetailed('jonathan', 'm');
	console.log('theDetails', theDetails);
  };
  
getDetailed();

Historical Name Data API

.getByName(name) returns name data for all years for a given name

.getByYear(year) returns name data for a specific year

.getById(id) returns a specific name record by id

.get(params) returns filtered name data where params are:

{
  id: int,
  name: string,
  year: int,
  yearRange: {start: int, end: int},
  sex: string (m/f),
  rank: int,
  rankRange: {start: int, end: int},
  births: int,
  birthsRange: {start: int, end: int},
  unique: boolean
}

Output from all the functions above looks like this:

[
	{ id: 784623,
	name: 'jonathan',
	sex: 'm',
	births: 10919,
	rank: 30,
	year: 1975 }
]

.getNameRankAndBirthsByYear(name, params) is useful for creating graphs. Params are:

{
	sex: boolean (M/F),
	getEmptyYears: boolean (include years even with 0 births)
}

Output for .getNameRankAndBirthsByYear("kanye") looks like:

{ '2002': { births: 5, rank: 11584 },
  '2003': { births: 87, rank: 1491 },
  '2004': { births: 507, rank: 489 },
  '2005': { births: 202, rank: 893 },
  '2006': { births: 101, rank: 1503 },
  '2007': { births: 53, rank: 2425 },
  '2008': { births: 81, rank: 1815 },
  '2009': { births: 64, rank: 2128 },
  '2010': { births: 30, rank: 3575 },
  '2011': { births: 35, rank: 3200 },
  '2012': { births: 34, rank: 3262 },
  '2013': { births: 40, rank: 2861 },
  '2014': { births: 22, rank: 4429 } }

Detailed Name Data API

.getDetailed(name, sex) returns advanced data about a given name including pronunciation, country of origin, meaning, and notes.

[
  {
    id: 88737,
    name: 'bertha',
    sex: 'm',
    nameData: {
	"name": "Bertha",
	"sex": "female",
	"pronunciation": "/ˈbɜːrθə/",
	"country": [
		"Germany",
			"England"
	],
	"meaning": [
		{
		"German": "bright one, glorious"
		}
	],
	"notes": "The name Bertha is of Germanic origin, derived from the Old High
		German word 'beraht', meaning 'bright' or 'glorious'. It has been used since
		 the Middle Ages, with notable usage recorded in German-speaking regions.
		Bertha was popular among various European royal families, most famously
		Bertha of the Merovingians, a Frankish queen in the late 5th century.
		The name was especially popular in the 19th century in England and
		Germany, often associated with nobility."
	}
  }
]

Direct DB Access via JS

Cut out the middleman and save! usBabyNames exposes the underlying sqliteDBs straight from the library.

const directDbAccess = async () => {
    const usBabyNamesModule = await import('../lib/usBabyNames.mjs');
    const nameDataDb = usBabyNamesModule.nameDataDb;
    const nameDetailsDb = usBabyNamesModule.nameDetailsDb;
    const nameDetailsSql = "SELECT * from usNameDetails where name = 'jonathan' and sex = 'm' ";
    nameDetailsDb.all(nameDetailsSql, [], (err, rows) => {
        if (err) {
            console.log('err', err);
            console.log (err);
        }
        console.log(rows);
    });

    const nameDataSql = "SELECT * from usNameData where name = 'jonathan' AND sex = 'm' ORDER BY year DESC limit 10";
    nameDataDb.all(nameDataSql, [], (err, rows) => {
        if (err) {
            console.log('err', err);
            console.log (err);
        }
        console.log(rows);
    });


};

directDbAccess();

Example Application

exampleUsBabyNamesVisualization.js: a really basic example of usBabyNames.js, express.js, and Google charts.js.

US Baby Names 1880-2023 Sqlite3 Database

Public domain.

Many people find the US Social Security Administration names files more useful in a sqlite database. For raw access to sql tables, just clone this repository and start querying.

I've done all the "hard" work of exporting all the historical United States birth name data from the original files (/raw_name_source) into a sqlite database. (It's not a hard thing to do, per se, it's just time consuming to load all the data... like over an hour running full speed ahead on a Macbook Pro with a SSD.) If you're curious how I did it, take a look at sqllite/loader.js. It ain't nothin' fancy. Presumably, it wouldn't be hard to modify it to load yob (year of birth) files into the database of your choice.

This database is 100% public domain and freely available for whatever purposes you like. Enjoy! Thanks SSA!

You can access the baby name sqlite database directly from the command line like so:

# sqlite3 sqlite/us-name-data.sqlite

select * from usNameData WHERE name = 'jonathan' AND year = 1975 AND sex = 'm';

Name Meanings / Pronunciation / Details database

Public domain.

Generated by Chat GPT-4o-mini over the course of a few days in early August 2024, good enough to be useful and helpful, probably a little messsy behind the scenes. Any improvements are more than welcome -- especially if somebody wants to run a portion of name set through a fancier model.

# sqlite3 sqlite/us-name-details.sqlite 

select * from usNameDetails where name = 'bertha' AND sex = 'f';

USA Historical Name Data Source: Government Fine Print

.. from the Original YOB Source Files:

National Data on the relative frequency of given names in the population of U.S. births where the individual has a Social Security Number

(Tabulated based on Social Security records as of March 6, 2016)

For each year of birth YYYY after 1879, we created a comma-delimited file called yobYYYY.txt. Each record in the individual annual files has the format "name,sex,number," where name is 2 to 15 characters, sex is M (male) or F (female) and "number" is the number of occurrences of the name. Each file is sorted first on sex and then on number of occurrences in descending order. When there is a tie on the number of occurrences, names are listed in alphabetical order. This sorting makes it easy to determine a name's rank. The first record for each sex has rank 1, the second record for each sex has rank 2, and so forth.

To safeguard privacy, we restrict our list of names to those with at least 5 occurrences.

Why

Written over a weekend in early 2016, usBabyNames.js was created when Jon Roig (@runnr_az) found existing baby name data websites / apps / etc... to be totally ridiculous. Since all of these other resources build off the same central resource, the Social Security Administration baby names files, and I was parsing the data anyway, I thought it'd be fun to learn how to package the whole thing up as an NPM module for anyone to use in the future.