Survei Komunitas Amerika: Perubahan Tahunan

Menganalisis Data Sensus AS dengan Python

Lee Hachadoorian

Asst. Professor of Instruction, Temple University

Sejarah Sensus: Hitungan dan Sampel

Hitungan penuh karakteristik demografis inti:

  • Sensus Sepuluh Tahunan 1790–2010+

Sampel karakteristik sosial dan ekonomi yang luas:

  • "Long Form" Sensus Sepuluh Tahunan (SF3) 1970–2000, ~15% rumah tangga
  • Survei Komunitas Amerika tahunan 2005+, ~1% rumah tangga
Menganalisis Data Sensus AS dengan Python

B25045 - Status Hunian menurut Ketersediaan Kendaraan dan Usia

Variable   |  Label
-----------|--------------------------------------
B25045001  |  Total
B25045002  |    Pemilik Hunian
B25045003  |      Tanpa Kendaraan
B25045004  |        Kepala Rumah Tangga 15–34 Tahun
B25045005  |        Kepala Rumah Tangga 35–64 Tahun
B25045006  |        Kepala Rumah Tangga 65+ Tahun
B25045007  |      ≥1 Kendaraan
B25045008  |        Kepala Rumah Tangga 15–34 Tahun
B25045009  |        Kepala Rumah Tangga 35–64 Tahun
B25045010  |        Kepala Rumah Tangga 65+ Tahun
B25045011  |    Penyewa
B25045012  |      Tanpa Kendaraan
B25045013  |        Kepala Rumah Tangga 15–34 Tahun
B25045014  |        Kepala Rumah Tangga 35–64 Tahun
B25045015  |        Kepala Rumah Tangga 65+ Tahun
B25045016  |      ≥1 Kendaraan
B25045017  |        Kepala Rumah Tangga 15–34 Tahun
B25045018  |        Kepala Rumah Tangga 35–64 Tahun
B25045019  |        Kepala Rumah Tangga 65+ Tahun
Menganalisis Data Sensus AS dengan Python

Permintaan Tabel Rinci ACS - Penyiapan

import requests
import pandas as pd

HOST, dataset = "https://api.census.gov/data", "acs/acs1"

get_vars = ["B25045_" + str(i + 1).zfill(3) + "E" for i in range(19)] get_vars = ["NAME"] + get_vars
print(get_vars)
['NAME', 'B25045_001E', 'B25045_002E', 'B25045_003E', 'B25045_004E', 
'B25045_005E', 'B25045_006E', 'B25045_007E', 'B25045_008E', 'B25045_009E', 
'B25045_010E', 'B25045_011E', 'B25045_012E', 'B25045_013E', 'B25045_014E', 
'B25045_015E', 'B25045_016E', 'B25045_017E', 'B25045_018E', 'B25045_019E']
Menganalisis Data Sensus AS dengan Python

Permintaan Tabel Rinci ACS - Penyiapan

import requests
import pandas as pd

HOST, dataset = "https://api.census.gov/data", "acs/acs1"

get_vars = ["B25045_" + str(i + 1).zfill(3) + "E" for i in range(19)] get_vars = ["NAME"] + get_vars
# print(get_vars)
predicates = {} predicates["get"] = ",".join(get_vars) predicates["for"] = "us:*"
Menganalisis Data Sensus AS dengan Python

Meminta Variabel yang Sama dari Beberapa Tahun

# Initialize DataFrame collector
dfs = []

for year in range(2011, 2018):
base_url = "/".join([HOST, str(year), dataset]) r = requests.get(base_url, params=predicates)
df = pd.DataFrame(columns=r.json()[0], data=r.json()[1:])
# Add column to hold year value df["year"] = year
dfs.append(df)
# Concatenate all DataFrames in collector us = pd.concat(dfs, ignore_index=True)
Menganalisis Data Sensus AS dengan Python

Meminta Variabel yang Sama dari Beberapa Tahun

print(us.head())
            NAME B25045_001E B25045_002E  ... B25045_019E us  year
0  United States   114991725    74264435  ...     3232812  1  2011
1  United States   115969540    74119256  ...     3447172  1  2012
2  United States   116291033    73843861  ...     3662322  1  2013
3  United States   117259427    73991995  ...     3847400  1  2014
4  United States   118208250    74506512  ...     4044430  1  2015

[5 rows x 22 columns]
Menganalisis Data Sensus AS dengan Python

Mari Ambil Data!

Menganalisis Data Sensus AS dengan Python

Preparing Video For Download...