从网站以数字格式而非字符读取数据集

时间:2018-05-15 10:28:05

标签: r rvest

使用下面的代码我从网站上读取数据 问题是它将数据读作character而不是numeric格式,特别是某些列,例如" Enlem(N)和Boylam(E)。

我该如何解决这个问题?

library(rvest)

widths <- c(11,10,10,10,14,5,5,5,48,100)
dat <- "http://www.koeri.boun.edu.tr/scripts/lst5.asp" %>%
    read_html %>%
    html_nodes("pre") %>%
    html_text %>%
    textConnection %>%
    read.fwf(widths = widths, stringsAsFactors = FALSE) %>%
    setNames(nm = .[6,]) %>%
    tail(-7) %>%
    head(-2)

1 个答案:

答案 0 :(得分:0)

如果您知道哪些特定列应为数字,则可以将这些列转换为数字。如果您不知道哪些列应该是数字,则可以创建一个函数来查看数据,如果列中的大小百分比的数字是一个数字,则将该列更改为数字。为此,我使用了以下功能:

NumericColumns <- function(x, AllowedPercentNumeric =.95, PreserveDate=TRUE, PreserveColumns){

  # find the counts of NA values in input data frame's columns
  param_originalNA <- apply(x, 2, function(z){sum(is.na(z))})

  # blindly coerce data.frame to numeric
  df_JustNumbers <- suppressWarnings(as.data.frame(lapply(x, as.numeric)))

  # Percent Non-NA values in each column
  PercentNumeric <- (apply(df_JustNumbers, 2, function(x)sum(!is.na(x))))/(nrow(x)-param_originalNA)

  rm(param_originalNA)

  # identify columns which have a greater than or equal percentage of numeric as specified
  param_numeric <- names(PercentNumeric)[PercentNumeric >= AllowedPercentNumeric]

  # Remove columns from list to convert to numeric that are specified as to preserve
  if (!missing(PreserveColumns)){param_numeric <- setdiff(param_numeric, PreserveColumns)}

  # Identify columns that are dates initially
  IsDateColumns <- lapply(x, function(y)(is(y, "Date")|is(y, "POSIXct")))
  param_dates <- names(IsDateColumns)[IsDateColumns==TRUE]

  # Remove dates from list if specified to preserve dates
  if (PreserveDate){param_numeric <- setdiff(param_numeric, param_dates)}

  # returns column position of numeric columns in target data frame
  param_numeric <- match(param_numeric, colnames(df_JustNumbers))

  # removes NA's from column list
  param_numeric <- param_numeric[complete.cases(param_numeric)]

  # coerces columns in param_numeric to numeric and inserts numeric columns into target data.frame
  if(length(param_numeric)==1){
    suppressWarnings(x[, param_numeric] <- as.numeric(x[, param_numeric]))
  }

  if(length(param_numeric)>1){
    suppressWarnings(x[, param_numeric] <- apply(x[, param_numeric],2, function(x)as.numeric(x)))
  }

  return(x)
}

创建功能后,您可以在数据上使用它,例如:

# Use function to convert to numeric 
dat <- NumericColumns(dat)