Мы можем использовать extract
из tidyr
, чтобы отделить значение и единицу и передать их в conv_unit
, используя map2
:
df <- data.frame(Measurements =c(NA, "1.25m", "2 Feet", "3 Inches", "5.5 cm"))
library(tidyverse)
library(stringr)
library(measurements)
df %>%
extract(Measurements, c("value", "unit"),
regex = "^([\\d.]+)\\s*([[:alpha:]]+)$",
remove = FALSE, convert = TRUE) %>%
mutate(unit = str_replace_all(unit, c(Feet="ft", Inches="inch")),
MM_Conversion = paste0(map2(value, unit, ~if(!is.na(.x)) conv_unit(.x, .y, "mm") else NA), "mm"))
Результат:
Measurements value unit MM_Conversion
1 <NA> NA <NA> NAmm
2 1.25m 1.25 m 1250mm
3 2 Feet 2.00 ft 609.6mm
4 3 Inches 3.00 inch 76.2mm
5 5.5 cm 5.50 cm 55mm
или используйте filter
, если NA
s не должны появиться в конечном выводе:
df %>%
extract(Measurements, c("value", "unit"),
regex = "^([\\d.]+)\\s*([[:alpha:]]+)$",
remove = FALSE, convert = TRUE) %>%
filter(!is.na(Measurements)) %>%
mutate(unit = str_replace_all(unit, c(Feet="ft", Inches="inch")),
MM_Conversion = paste0(map2(value, unit, ~conv_unit(.x, .y, "mm")), "mm"))
Результат:
Measurements value unit MM_Conversion
1 1.25m 1.25 m 1250mm
2 2 Feet 2.00 ft 609.6mm
3 3 Inches 3.00 inch 76.2mm
4 5.5 cm 5.50 cm 55mm
Обратите внимание, как я вручную сократил исходные единицы, чтобы заставить conv_unit
работать. Было бы на один шаг меньше, если бы исходные единицы были уже в сокращенной форме.