Nothing
#' Scrapes SINASC data from regions
#'
#' This function allows the user to retrive data from
#' SINASC database much in the same way that is done
#' by the online portal. The argument options refer to
#' data focused on the regions and states.
#'
#' @usage sinasc_nv_bruf(linha = "Região", coluna = "Não ativa",
#' conteudo = 1, periodo = "last", regiao = "all", unidade_da_federacao = "all",
#' local_ocorrencia = "all", idade_da_mae = "all", instrucao_da_mae = "all",
#' estado_civil_mae = "all", duracao_gestacao = "all", tipo_de_gravidez = "all",
#' tipo_de_parto = "all", consult_pre_natal = "all", sexo = "all",
#' cor_raca = "all", apgar_1_minuto = "all", apgar_5_minuto = "all",
#' peso_ao_nascer = "all", anomalia_congenita = "all", tipo_anomal_congen = "all")
#' @param linha A character describing which element will be displayed in the rows of the data.frame. Defaults to "Município".
#' @param coluna A character describing which element will be displayed in the columns of the data.frame. Defaults to "Não ativa".
#' @param conteudo A character of length = 1 with the state's acronym of interest.
#' @param periodo A character vector describing the period of data. Defaults to the last available.
#' @param regiao "all" or a numeric vector with the IBGE's region codes to filter the data. Defaults to "all".
#' @param unidade_da_federacao "all" or a numeric vector with the IBGE's state codes to filter the data. Defaults to "all".
#' @param local_ocorrencia "all" or a character vector with the place of ocurrence to filter the data. Defaults to "all".
#' @param idade_da_mae "all" or a character vector with the age range (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param instrucao_da_mae "all" or a character vector with the mother's instruction (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param estado_civil_mae "all" or a character vector with the marital status of the mother (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param duracao_gestacao "all" or a character vector with the marital status of the mother (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param tipo_de_gravidez "all" or a character vector with the type of pregnancy (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param tipo_de_parto "all" or a character vector with the Parturition type (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param consult_pre_natal "all" or a character vector with the amount of prenatal consultation (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param sexo "all" or a character vector with the gender (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param cor_raca "all" or a character vector with the color/race (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param apgar_1_minuto "all" or a character vector with the value of the apgar exam of the first minute (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param apgar_5_minuto "all" or a character vector with the value of the apgar exam of the fifth minute (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param peso_ao_nascer "all" or a character vector with the birth weight (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param anomalia_congenita "all" or a character vector with the indicative of congenital anomaly (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @param tipo_anomal_congen "all" or a character vector with the congenital anomaly type (written in the same way) or the number corresponding to the order of the option in the online layout to filter the data. Defaults to "all".
#' @return The function returns a data frame printed by parameters input.
#' @author Renato Prado Siqueira \email{<rpradosiqueira@@gmail.com>}
#' @seealso \code{\link{sinasc_nv_uf}}
#' @examples
#' \dontrun{
#' ## Requesting data from Midwest region
#' sinasc_nv_bruf(region = 5)
#' }
#'
#' @keywords SINASC datasus
#' @importFrom magrittr %>%
#' @importFrom utils head
#' @export
sinasc_nv_bruf <- function(linha = "Regi\u00e3o", coluna = "N\u00e3o ativa", conteudo = 1, periodo = "last", regiao = "all", unidade_da_federacao = "all",
local_ocorrencia = "all", idade_da_mae = "all", instrucao_da_mae = "all", estado_civil_mae = "all",
duracao_gestacao = "all", tipo_de_gravidez = "all", tipo_de_parto = "all", consult_pre_natal = "all",
sexo = "all", cor_raca = "all", apgar_1_minuto = "all", apgar_5_minuto = "all", peso_ao_nascer = "all",
anomalia_congenita = "all", tipo_anomal_congen = "all") {
page <- xml2::read_html("http://tabnet.datasus.gov.br/cgi/deftohtm.exe?sinasc/cnv/nvuf.def")
#### DF ####
linha.df <- data.frame(id = page %>% rvest::html_nodes("#L option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#L option") %>% rvest::html_attr("value"))
linha.df[] <- lapply(linha.df, as.character)
coluna.df <- data.frame(id = page %>% rvest::html_nodes("#C option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#C option") %>% rvest::html_attr("value"))
coluna.df[] <- lapply(coluna.df, as.character)
conteudo.df <- data.frame(id1 = c(1, 2),
id2 = c("Nascim p/resid.m\u00e3e", "Nascim p/ocorr\u00eanc"),
value = c("Nascim_p/resid.m\u00e3e", "Nascim_p/ocorr\u00eanc"))
periodos.df <- data.frame(id = page %>% rvest::html_nodes("#A option") %>% rvest::html_text() %>% as.numeric(),
value = page %>% rvest::html_nodes("#A option") %>% rvest::html_attr("value"))
regiao.df <- suppressWarnings(data.frame(id = page %>% rvest::html_nodes("#S1 option") %>% rvest::html_text() %>% readr::parse_number(),
value = page %>% rvest::html_nodes("#S1 option") %>% rvest::html_attr("value")))
unidade_da_federacao.df <- suppressWarnings(data.frame(id = page %>% rvest::html_nodes("#S2 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S2 option") %>% rvest::html_attr("value")))
unidade_da_federacao.df[] <- lapply(unidade_da_federacao.df, as.character)
local_ocorrencia.df <- data.frame(id = page %>% rvest::html_nodes("#S3 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S3 option") %>% rvest::html_attr("value"))
local_ocorrencia.df[] <- lapply(local_ocorrencia.df, as.character)
idade_da_mae.df <- data.frame(id = page %>% rvest::html_nodes("#S4 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S4 option") %>% rvest::html_attr("value"))
idade_da_mae.df[] <- lapply(idade_da_mae.df, as.character)
instrucao_da_mae.df <- data.frame(id = page %>% rvest::html_nodes("#S5 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S5 option") %>% rvest::html_attr("value"))
instrucao_da_mae.df[] <- lapply(instrucao_da_mae.df, as.character)
estado_civil_mae.df <- data.frame(id = page %>% rvest::html_nodes("#S6 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S6 option") %>% rvest::html_attr("value"))
estado_civil_mae.df[] <- lapply(estado_civil_mae.df, as.character)
duracao_gestacao.df <- data.frame(id = page %>% rvest::html_nodes("#S7 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S7 option") %>% rvest::html_attr("value"))
duracao_gestacao.df[] <- lapply(duracao_gestacao.df, as.character)
tipo_de_gravidez.df <- data.frame(id = page %>% rvest::html_nodes("#S8 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S8 option") %>% rvest::html_attr("value"))
tipo_de_gravidez.df[] <- lapply(tipo_de_gravidez.df, as.character)
tipo_de_parto.df <- data.frame(id = page %>% rvest::html_nodes("#S9 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S9 option") %>% rvest::html_attr("value"))
tipo_de_parto.df[] <- lapply(tipo_de_parto.df, as.character)
consult_pre_natal.df <- data.frame(id = page %>% rvest::html_nodes("#S10 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S10 option") %>% rvest::html_attr("value"))
consult_pre_natal.df[] <- lapply(consult_pre_natal.df, as.character)
sexo.df <- data.frame(id = page %>% rvest::html_nodes("#S11 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S11 option") %>% rvest::html_attr("value"))
sexo.df[] <- lapply(sexo.df, as.character)
cor_raca.df <- data.frame(id = page %>% rvest::html_nodes("#S12 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S12 option") %>% rvest::html_attr("value"))
cor_raca.df[] <- lapply(cor_raca.df, as.character)
apgar_1_minuto.df <- data.frame(id = page %>% rvest::html_nodes("#S13 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S13 option") %>% rvest::html_attr("value"))
apgar_1_minuto.df[] <- lapply(apgar_1_minuto.df, as.character)
apgar_5_minuto.df <- data.frame(id = page %>% rvest::html_nodes("#S14 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S14 option") %>% rvest::html_attr("value"))
apgar_5_minuto.df[] <- lapply(apgar_5_minuto.df, as.character)
peso_ao_nascer.df <- data.frame(id = page %>% rvest::html_nodes("#S15 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S15 option") %>% rvest::html_attr("value"))
peso_ao_nascer.df[] <- lapply(peso_ao_nascer.df, as.character)
anomalia_congenita.df <- data.frame(id = page %>% rvest::html_nodes("#S16 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S16 option") %>% rvest::html_attr("value"))
anomalia_congenita.df[] <- lapply(anomalia_congenita.df, as.character)
tipo_anomal_congen.df <- data.frame(id = page %>% rvest::html_nodes("#S17 option") %>% rvest::html_text() %>% trimws(),
value = page %>% rvest::html_nodes("#S17 option") %>% rvest::html_attr("value"))
tipo_anomal_congen.df[] <- lapply(tipo_anomal_congen.df, as.character)
regiao.df$id[1] <- unidade_da_federacao.df$id[1] <- local_ocorrencia.df$id[1]<- idade_da_mae.df$id[1] <- instrucao_da_mae.df$id[1] <- "all"
estado_civil_mae.df$id[1] <- duracao_gestacao.df$id[1] <- tipo_de_gravidez.df$id[1] <- tipo_de_parto.df$id[1] <- "all"
consult_pre_natal.df$id[1] <- sexo.df$id[1] <- cor_raca.df$id[1] <- apgar_1_minuto.df$id[1] <- apgar_5_minuto.df$id[1] <- "all"
peso_ao_nascer.df$id[1] <- anomalia_congenita.df$id[1] <- tipo_anomal_congen.df$id[1] <- "all"
#### ERROR HANDLING ####
if (linha != "Regi\u00e3o") {
if (!is.character(linha)) stop("The 'linha' argument must be a character element")
if(length(linha) != 1) stop("The 'linha' argument must have only one element")
if (!(all(linha %in% linha.df$id))) {
if (!(all(linha %in% linha.df$value))) {
stop("The 'linha' argument is misspecified")
}
}
}
if (coluna != "N\u00e3o ativa") {
if (!is.character(coluna)) stop("The 'coluna' argument must be a character element")
if(length(coluna) != 1) stop("The 'coluna' argument must have only one element")
if (!(all(coluna %in% coluna.df$id))) {
if (!(all(coluna %in% coluna.df$value))) {
stop("The 'coluna' argument is misspecified")
}
}
}
if (conteudo != 1 & conteudo != 2) {
if (is.numeric(conteudo)) stop("The only numeric elements allowed are 1 or 2")
if(length(conteudo) != 1) stop("The 'coluna' argument must have only one element")
if (!(all(conteudo %in% conteudo.df$id2))) {
if (!(all(conteudo %in% conteudo.df$value))) {
stop("The 'conteudo' argument is misspecified")
}
}
}
if (periodo[1] != "last") {
if (is.character(periodo)) {
periodo <- as.numeric(periodo)
}
if (!(all(periodo %in% periodos.df$id))) stop("The 'periodo' argument is misspecified")
}
if (any(regiao != "all")) {
regiao <- as.character(regiao)
if (!(all(regiao %in% regiao.df$id))) stop("Some element in 'regiao' argument is wrong")
}
if (any(unidade_da_federacao != "all")) {
unidade_da_federacao <- as.character(unidade_da_federacao)
if (!(all(unidade_da_federacao %in% unidade_da_federacao.df$id))) stop("Some element in 'unidade_da_federacao' argument is wrong")
}
if (any(local_ocorrencia != "all")) {
if (!(all(local_ocorrencia %in% local_ocorrencia.df$id))) {
local_ocorrencia <- as.character(local_ocorrencia)
if (!(all(local_ocorrencia %in% local_ocorrencia.df$value))) {
stop("Some element in 'local_ocorrencia' argument is wrong")
}
}
}
if (any(idade_da_mae != "all")) {
if (!(all(idade_da_mae %in% idade_da_mae.df$id))) {
idade_da_mae <- as.character(idade_da_mae)
if (!(all(idade_da_mae %in% idade_da_mae.df$value))) {
stop("Some element in 'idade_da_mae' argument is wrong")
}
}
}
if (any(instrucao_da_mae != "all")) {
if (!(all(instrucao_da_mae %in% instrucao_da_mae.df$id))) {
instrucao_da_mae <- as.character(instrucao_da_mae)
if (!(all(instrucao_da_mae %in% instrucao_da_mae.df$value))) {
stop("Some element in 'instrucao_da_mae' argument is wrong")
}
}
}
if (any(estado_civil_mae != "all")) {
if (!(all(estado_civil_mae %in% estado_civil_mae.df$id))) {
estado_civil_mae <- as.character(estado_civil_mae)
if (!(all(estado_civil_mae %in% estado_civil_mae.df$value))) {
stop("Some element in 'estado_civil_mae' argument is wrong")
}
}
}
if (any(duracao_gestacao != "all")) {
if (!(all(duracao_gestacao %in% duracao_gestacao.df$id))) {
duracao_gestacao <- as.character(duracao_gestacao)
if (!(all(duracao_gestacao %in% duracao_gestacao.df$value))) {
stop("Some element in 'duracao_gestacao' argument is wrong")
}
}
}
if (any(tipo_de_gravidez != "all")) {
if (!(all(tipo_de_gravidez %in% tipo_de_gravidez.df$id))) {
tipo_de_gravidez <- as.character(tipo_de_gravidez)
if (!(all(tipo_de_gravidez %in% tipo_de_gravidez.df$value))) {
stop("Some element in 'tipo_de_gravidez' argument is wrong")
}
}
}
if (any(tipo_de_parto != "all")) {
if (!(all(tipo_de_parto %in% tipo_de_parto.df$id))) {
tipo_de_parto <- as.character(tipo_de_parto)
if (!(all(tipo_de_parto %in% tipo_de_parto.df$value))) {
stop("Some element in 'tipo_de_parto' argument is wrong")
}
}
}
if (any(consult_pre_natal != "all")) {
if (!(all(consult_pre_natal %in% consult_pre_natal.df$id))) {
consult_pre_natal <- as.character(consult_pre_natal)
if (!(all(consult_pre_natal %in% consult_pre_natal.df$value))) {
stop("Some element in 'consult_pre_natal' argument is wrong")
}
}
}
if (any(sexo != "all")) {
if (!(all(sexo %in% sexo.df$id))) {
sexo <- as.character(sexo)
if (!(all(sexo %in% sexo.df$value))) {
stop("Some element in 'sexo' argument is wrong")
}
}
}
if (any(cor_raca != "all")) {
if (!(all(cor_raca %in% cor_raca.df$id))) {
cor_raca <- as.character(cor_raca)
if (!(all(cor_raca %in% cor_raca.df$value))) {
stop("Some element in 'cor_raca' argument is wrong")
}
}
}
if (any(apgar_1_minuto != "all")) {
if (!(all(apgar_1_minuto %in% apgar_1_minuto.df$id))) {
apgar_1_minuto <- as.character(apgar_1_minuto)
if (!(all(apgar_1_minuto %in% apgar_1_minuto.df$value))) {
stop("Some element in 'apgar_1_minuto' argument is wrong")
}
}
}
if (any(apgar_5_minuto != "all")) {
if (!(all(apgar_5_minuto %in% apgar_5_minuto.df$id))) {
apgar_5_minuto <- as.character(apgar_5_minuto)
if (!(all(apgar_5_minuto %in% apgar_5_minuto.df$value))) {
stop("Some element in 'apgar_5_minuto' argument is wrong")
}
}
}
if (any(peso_ao_nascer != "all")) {
if (!(all(peso_ao_nascer %in% peso_ao_nascer.df$id))) {
peso_ao_nascer <- as.character(peso_ao_nascer)
if (!(all(peso_ao_nascer %in% peso_ao_nascer.df$value))) {
stop("Some element in 'peso_ao_nascer' argument is wrong")
}
}
}
if (any(anomalia_congenita != "all")) {
if (!(all(anomalia_congenita %in% anomalia_congenita.df$id))) {
anomalia_congenita <- as.character(anomalia_congenita)
if (!(all(anomalia_congenita %in% anomalia_congenita.df$value))) {
stop("Some element in 'anomalia_congenita' argument is wrong")
}
}
}
if (any(tipo_anomal_congen != "all")) {
if (!(all(tipo_anomal_congen %in% tipo_anomal_congen.df$id))) {
tipo_anomal_congen <- as.character(tipo_anomal_congen)
if (!(all(tipo_anomal_congen %in% tipo_anomal_congen.df$value))) {
stop("Some element in 'tipo_anomal_congen' argument is wrong")
}
}
}
#### FILTERS APPLICATIONS ####
#linha
if (linha %in% linha.df$id) {
linha <- dplyr::filter(linha.df, linha.df$id %in% linha)
linha <- linha$value
}
if (!stringi::stri_enc_isascii(linha)) {
form_linha <- paste0("Linha=", stringi::stri_escape_unicode(linha))
} else {
form_linha <- paste0("Linha=", linha)
}
#coluna
if (coluna %in% coluna.df$id) {
coluna <- dplyr::filter(coluna.df, coluna.df$id %in% coluna)
coluna <- coluna$value
}
if (!stringi::stri_enc_isascii(coluna)) {
form_coluna <- paste0("Coluna=", stringi::stri_escape_unicode(coluna))
} else {
form_coluna <- paste0("Coluna=", coluna)
}
#conteudo
form_conteudo <- conteudo.df$value[conteudo]
if (!stringi::stri_enc_isascii(form_conteudo)) {
form_conteudo <- paste0("Incremento=", stringi::stri_escape_unicode(form_conteudo))
} else {
form_conteudo <- paste0("Incremento=", form_conteudo)
}
#periodo
suppressWarnings( if (periodo == "last") {periodo <- utils::head(periodos.df$id, 1)} )
form_periodo <- dplyr::filter(periodos.df, periodos.df$id %in% periodo)
form_periodo <- paste0("Arquivos=", form_periodo$value, collapse = "&")
#regiao
form_regiao <- dplyr::filter(regiao.df, regiao.df$id %in% regiao)
form_regiao <- paste0("SRegi%E3o=", form_regiao$value, collapse = "&")
form_pesqmes2 <- "pesqmes2=Digite+o+texto+e+ache+f%E1cil"
#unidade_da_federacao
form_unidade_da_federacao <- dplyr::filter(unidade_da_federacao.df, unidade_da_federacao.df$id %in% unidade_da_federacao)
form_unidade_da_federacao <- paste0("SUnidade_da_Federa%E7%E3o=", form_unidade_da_federacao$value, collapse = "&")
#local_ocorrencia
form_local_ocorrencia <- dplyr::filter(local_ocorrencia.df, local_ocorrencia.df$id %in% local_ocorrencia)
form_local_ocorrencia <- paste0("SLocal_ocorr%EAncia=", form_local_ocorrencia$value, collapse = "&")
form_pesqmes4 <- "pesqmes4=Digite+o+texto+e+ache+f%E1cil"
#idade_da_mae
form_idade_da_mae <- dplyr::filter(idade_da_mae.df, idade_da_mae.df$id %in% idade_da_mae)
form_idade_da_mae <- paste0("SIdade_da_m%E3e=", form_idade_da_mae$value, collapse = "&")
form_pesqmes5 <- "pesqmes5=Digite+o+texto+e+ache+f%E1cil"
#instrucao_da_mae
form_instrucao_da_mae <- dplyr::filter(instrucao_da_mae.df, instrucao_da_mae.df$id %in% instrucao_da_mae)
form_instrucao_da_mae <- paste0("SInstru%E7%E3o_da_m%E3e=", form_instrucao_da_mae$value, collapse = "&")
#estado_civil_mae
form_estado_civil_mae <- dplyr::filter(estado_civil_mae.df, estado_civil_mae.df$id %in% estado_civil_mae)
form_estado_civil_mae <- paste0("SEstado_civil_m%E3e=", form_estado_civil_mae$value, collapse = "&")
#duracao_gestacao
form_duracao_gestacao <- dplyr::filter(duracao_gestacao.df, duracao_gestacao.df$id %in% duracao_gestacao)
form_duracao_gestacao <- paste0("SDura%E7%E3o_gesta%E7%E3o=", form_duracao_gestacao$value, collapse = "&")
#tipo_de_gravidez
form_tipo_de_gravidez <- dplyr::filter(tipo_de_gravidez.df, tipo_de_gravidez.df$id %in% tipo_de_gravidez)
form_tipo_de_gravidez <- paste0("STipo_de_gravidez=", form_tipo_de_gravidez$value, collapse = "&")
#tipo_de_parto
form_tipo_de_parto <- dplyr::filter(tipo_de_parto.df, tipo_de_parto.df$id %in% tipo_de_parto)
form_tipo_de_parto <- paste0("STipo_de_parto=", form_tipo_de_parto$value, collapse = "&")
#consult_pre_natal
form_consult_pre_natal <- dplyr::filter(consult_pre_natal.df, consult_pre_natal.df$id %in% consult_pre_natal)
form_consult_pre_natal <- paste0("SConsult_pr%E9-natal=", form_consult_pre_natal$value, collapse = "&")
#sexo
form_sexo <- dplyr::filter(sexo.df, sexo.df$id %in% sexo)
form_sexo <- paste0("SSexo=", form_sexo$value, collapse = "&")
#cor_raca
form_cor_raca <- dplyr::filter(cor_raca.df, cor_raca.df$id %in% cor_raca)
form_cor_raca <- paste0("SCor%2Fra%E7a=", form_cor_raca$value, collapse = "&")
#apgar_1_minuto
form_apgar_1_minuto <- dplyr::filter(apgar_1_minuto.df, apgar_1_minuto.df$id %in% apgar_1_minuto)
form_apgar_1_minuto <- paste0("SApgar_1%BA_minuto=", form_apgar_1_minuto$value, collapse = "&")
#apgar_5_minuto
form_apgar_5_minuto <- dplyr::filter(apgar_5_minuto.df, apgar_5_minuto.df$id %in% apgar_5_minuto)
form_apgar_5_minuto <- paste0("SApgar_5%BA_minuto=", form_apgar_5_minuto$value, collapse = "&")
#peso_ao_nascer
form_peso_ao_nascer <- dplyr::filter(peso_ao_nascer.df, peso_ao_nascer.df$id %in% peso_ao_nascer)
form_peso_ao_nascer <- paste0("SPeso_ao_nascer=", form_peso_ao_nascer$value, collapse = "&")
#anomalia_congenita
form_anomalia_congenita <- dplyr::filter(anomalia_congenita.df, anomalia_congenita.df$id %in% anomalia_congenita)
form_anomalia_congenita <- paste0("SAnomalia_cong%EAnita=", form_anomalia_congenita$value, collapse = "&")
form_pesqmes17 <- "pesqmes17=Digite+o+texto+e+ache+f%E1cil"
#tipo_anomal_congen
form_tipo_anomal_congen <- dplyr::filter(tipo_anomal_congen.df, tipo_anomal_congen.df$id %in% tipo_anomal_congen)
form_tipo_anomal_congen <- paste0("STipo_anomal_cong%EAn=", form_tipo_anomal_congen$value, collapse = "&")
form_data <- paste(form_linha, form_coluna, form_conteudo, form_periodo, form_regiao, form_pesqmes2,
form_unidade_da_federacao, form_local_ocorrencia, form_pesqmes4, form_idade_da_mae,
form_pesqmes5, form_instrucao_da_mae, form_estado_civil_mae, form_duracao_gestacao,
form_tipo_de_gravidez, form_tipo_de_parto, form_consult_pre_natal, form_sexo, form_cor_raca,
form_apgar_1_minuto, form_apgar_5_minuto, form_peso_ao_nascer, form_anomalia_congenita,
form_pesqmes17, form_tipo_anomal_congen, "formato=table&mostre=Mostra", sep = "&")
form_data <- gsub("\\\\u00", "%", form_data)
##### REQUEST FORM AND DATA WRANGLING ####
site <- httr::POST(url = "http://tabnet.datasus.gov.br/cgi/tabcgi.exe?sinasc/cnv/nvuf.def",
body = form_data)
tabdados <- httr::content(site, encoding = "Latin1") %>%
rvest::html_nodes(".tabdados tbody td") %>%
rvest::html_text() %>%
trimws()
col_tabdados <- httr::content(site, encoding = "Latin1") %>%
rvest::html_nodes("th") %>%
rvest::html_text() %>%
trimws()
f1 <- function(x) x <- gsub("\\.", "", x)
f2 <- function(x) x <- as.numeric(as.character(x))
tabela_final <- as.data.frame(matrix(data = tabdados, nrow = length(tabdados)/length(col_tabdados),
ncol = length(col_tabdados), byrow = TRUE))
names(tabela_final) <- col_tabdados
tabela_final[-1] <- lapply(tabela_final[-1], f1)
tabela_final[-1] <- suppressWarnings(lapply(tabela_final[-1], f2))
tabela_final
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.