Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 0 additions & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -68,4 +68,3 @@ Suggests:
tidyverse
Config/testthat/edition: 3
VignetteBuilder: knitr
Config/testthat/edition: 3
1 change: 1 addition & 0 deletions NAMESPACE
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export(get_government_finances)
export(get_hazard_mitigation_assistance)
export(get_ihp_registrations)
export(get_lodes)
export(get_naics_codes)
export(get_nfip_claims)
export(get_nfip_policies)
export(get_preliminary_damage_assessments)
Expand Down
58 changes: 57 additions & 1 deletion R/get_business_patterns.R
Original file line number Diff line number Diff line change
@@ -1,5 +1,61 @@
#' @importFrom magrittr %>%

#' @title Get NAICS Codes for County Business Patterns
#'
#' @description A utility function to programmatically identify and select NAICS
#' codes for use with `get_business_patterns()`. This is a wrapper around
#' `censusapi::listCensusMetadata(name = "cbp")`.
#'
#' @param year The vintage year for NAICS codes. Data are available from 1986 through 2023.
#' Default is 2022.
#' @param digits The number of digits for desired NAICS codes. Must be between 2 and 6.
#' Default is 3. Two-digit codes represent broad industry sectors (20 codes),
#' while six-digit codes represent detailed industries.
#'
#' @return A tibble with the following columns:
#' \describe{
#' \item{naics_code}{The NAICS code (character)}
#' \item{naics_label}{The descriptive label for the NAICS code}
#' \item{year}{The vintage year of the NAICS codes}
#' }
#'
#' @export
#'
#' @examples
#' \dontrun{
#' # Get all 2-digit NAICS codes
#' get_naics_codes(year = 2022, digits = 2)
#'
#' # Get all 3-digit NAICS codes (default)
#' get_naics_codes(year = 2022)
#'
#' # Get 4-digit NAICS codes for a specific year
#' get_naics_codes(year = 2020, digits = 4)
#' }
get_naics_codes <- function(year = 2022, digits = 3) {
if (year < 1986) { stop("Year must be 1986 or later.") }
if (year > 2023) { stop("Most recent year for data is 2023.") }
if (!digits %in% 2:6) { stop("`digits` must be between 2 and 6.") }

naics_metadata <- censusapi::listCensusMetadata(
name = "cbp",
vintage = as.character(year),
type = "variables",
include_values = TRUE) |>
dplyr::filter(
!is.na(values_code),
!stringr::str_starts(values_code, "92|95"),
nchar(values_code) == digits) |>
dplyr::transmute(
naics_code = values_code,
naics_label = values_label,
year = year) |>
dplyr::distinct() |>
dplyr::arrange(naics_code) |>
tibble::as_tibble()

}

#' @title Obtain County Business Patterns (CBP) Estimates per County
#'
#' @param year The vintage of CBP data desired. Data are available from 1986,
Expand Down Expand Up @@ -234,4 +290,4 @@ get_business_patterns = function(year = 2022, geo = "county", naics_code_digits
utils::globalVariables(
c("EMP", "EMPSZES", "ESTAB", "NAICS2017_LABEL", "PAYANN", "annual_payroll",
"employee_size_range", "employee_size_range_code", "employee_size_range_label",
"employees", "employers", "industry", "values_code", "naics_code"))
"employees", "employers", "industry", "values_code", "values_label", "naics_code"))
34 changes: 23 additions & 11 deletions man/cache_it.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion man/convert_delimited_to_parquet.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 7 additions & 1 deletion man/convert_table_text_to_dataframe.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 13 additions & 1 deletion man/estimate_units_per_parcel.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 4 additions & 1 deletion man/get_box_path.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion man/get_dataset_columns.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

10 changes: 9 additions & 1 deletion man/get_emergency_management_performance.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 6 additions & 1 deletion man/get_geography_metadata.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

15 changes: 14 additions & 1 deletion man/get_government_finances.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 13 additions & 1 deletion man/get_ihp_registrations.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

41 changes: 41 additions & 0 deletions man/get_naics_codes.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading