将具有3个参数的函数应用于数据框中的每一行

时间:2019-01-31 06:01:06

标签: r function apply multiple-arguments

我正在尝试将函数应用于R中数据帧的每一行。我已经在Stack Overflow中经历了几个答案,但是它们不起作用。

基本上,我有一个经度和纬度信息的数据框。函数convertLngs2接受3个输入->来自数据帧的经度信息列,源经度和目标经度。如果源经度和目标经度之差大于180度,则经度列中的所有负值都需要增加360度。

library(dplyr)
library(geosphere)

# Source
latWaterloo <- 43.46687 
lngWaterloo <- -80.52464

# Destination
latTaiwan <- 23.5983
lngTaiwan <- 120.8354


convertLngs2 <- function(lonn, srcLng, sonLng) {
  diffr <- abs(srcLng) + abs(sonLng)
  if (diffr > 180) {
    if (lonn<0) {
      lonn <- lonn + 360
    } else {
      lonn <- lonn
    } 
  } else {
    lonn <- lonn
  } 
}


geo_lines <- gcIntermediate(c(lngWaterloo, latWaterloo), c(lngTaiwan, latTaiwan), n=100, addStartEnd=T, sp=F)
geo_lines <- data.frame(geo_lines)

geo_lines2 <- geo_lines %>% mutate(lon=sapply(lon, convertLngs2(lon, lngWaterloo, lngTaiwan)))

geo_lines3 <- geo_lines %>% mutate(lon=convertLngs2(lon, lngWaterloo, lngTaiwan))

geo_lines4 <- geo_lines %>% mutate(lon=lapply(lon, convertLngs2(lon, lngWaterloo, lngTaiwan)))

geo_lines5 <- geo_lines %>% mutate(lon=apply(lon, 1, convertLngs2(lon, lngWaterloo, lngTaiwan)))

我需要在函数中保留srcLng和sonLng的参数。我尝试了sapply,lapply和apply,但是它们都给出以下错误:

Error in mutate_impl(.data, dots) : 
  Evaluation error: 'convertLngs2(lon, lngWaterloo, lngTaiwan)' is not a function, character or symbol.
In addition: Warning message:
In if (lonn < 0) { :
  the condition has length > 1 and only the first element will be used

要使代码生效,需要进行哪些更改?谢谢!

0 个答案:

没有答案