Відповіді:
Загалом, ми хочемо, щоб рішення було векторизованим, тому ось кращий тестовий приклад:
whitespace <- " \t\n\r\v\f" # space, tab, newline,
# carriage return, vertical tab, form feed
x <- c(
" x y ", # spaces before, after and in between
" \u2190 \u2192 ", # contains unicode chars
paste0( # varied whitespace
whitespace,
"x",
whitespace,
"y",
whitespace,
collapse = ""
),
NA # missing
)
## [1] " x y "
## [2] " ← → "
## [3] " \t\n\r\v\fx \t\n\r\v\fy \t\n\r\v\f"
## [4] NA
gsub
gsub
замінює всі екземпляри рядка ( fixed = TRUE
) або регулярного виразу ( fixed = FALSE
, за замовчуванням) іншим рядком. Щоб видалити всі пробіли, використовуйте:
gsub(" ", "", x, fixed = TRUE)
## [1] "xy" "←→"
## [3] "\t\n\r\v\fx\t\n\r\v\fy\t\n\r\v\f" NA
Як зауважив DWin, в цьому випадку fixed = TRUE
це не потрібно, але забезпечує дещо кращу ефективність, оскільки відповідність фіксованій рядку швидше, ніж відповідність звичайному виразу.
Якщо ви хочете видалити всі типи пробілів, використовуйте:
gsub("[[:space:]]", "", x) # note the double square brackets
## [1] "xy" "←→" "xy" NA
gsub("\\s", "", x) # same; note the double backslash
library(regex)
gsub(space(), "", x) # same
"[:space:]"
являє собою R-специфічну групу регулярних виразів, яка відповідає всім символам простору. \s
це незалежне від мови регулярне вираження, яке робить те саме.
stringr
Підхід: str_replace_all
іstr_trim
stringr
надає більше обговорюваних людиною обгортків навколо базових функцій R (хоча станом на грудень 2014 року, версія для розробки має гілку stringi
, згадану нижче). Еквівалентами вищезазначених команд, використовуючи [ str_replace_all][3]
, є:
library(stringr)
str_replace_all(x, fixed(" "), "")
str_replace_all(x, space(), "")
stringr
також має str_trim
функцію, яка видаляє лише провідні та кінцеві пробіли.
str_trim(x)
## [1] "x y" "← →" "x \t\n\r\v\fy" NA
str_trim(x, "left")
## [1] "x y " "← → "
## [3] "x \t\n\r\v\fy \t\n\r\v\f" NA
str_trim(x, "right")
## [1] " x y" " ← →"
## [3] " \t\n\r\v\fx \t\n\r\v\fy" NA
stringi
Підхід: stri_replace_all_charclass
іstri_trim
stringi
побудований на основі незалежної від платформи бібліотеки ICU і має широкий набір функцій маніпулювання рядками. Ці еквіваленти вищевказаних є:
library(stringi)
stri_replace_all_fixed(x, " ", "")
stri_replace_all_charclass(x, "\\p{WHITE_SPACE}", "")
Ось "\\p{WHITE_SPACE}"
альтернативний синтаксис для безлічі кодових точок Unicode вважаються пробілами, що еквівалентно "[[:space:]]"
, "\\s"
і space()
. Також є складніші заміни регулярного вираження stri_replace_all_regex
.
stringi
також має функції обрізки .
stri_trim(x)
stri_trim_both(x) # same
stri_trim(x, "left")
stri_trim_left(x) # same
stri_trim(x, "right")
stri_trim_right(x) # same
"[[:space:]]"
і "\\s"
?
Я щойно дізнався про пакет "stringr" для видалення пробілів з початку та кінця рядка з str_trim (, side = "обидва"), але він також має функцію заміни, щоб:
a <- " xx yy 11 22 33 "
str_replace_all(string=a, pattern=" ", repl="")
[1] "xxyy112233"
Зверніть увагу, що написані вище душі видаляють лише простір. Якщо ви хочете також видалити вкладку або використовувати новий рядок stri_replace_all_charclass
з stringi
пакета.
library(stringi)
stri_replace_all_charclass(" ala \t ma \n kota ", "\\p{WHITE_SPACE}", "")
## [1] "alamakota"
stringi
пакет зараз на CRAN, насолоджуйтесь! :)
stringi
протягом декількох місяців , і тепер бачив / дізналися , наскільки потужним і ефективним воно, воно стало моїм йти до пакету для строкових операцій. Ви, хлопці, зробили з цим приголомшливу роботу.
Використовуйте [[:blank:]]
для порівняння будь-яких видів горизонтальних символів white_space.
gsub("[[:blank:]]", "", " xx yy 11 22 33 ")
# [1] "xxyy112233"
Функція str_squish()
з пакета stringr
tidyverse виконує магію!
library(dplyr)
library(stringr)
df <- data.frame(a = c(" aZe aze s", "wxc s aze "),
b = c(" 12 12 ", "34e e4 "),
stringsAsFactors = FALSE)
df <- df %>%
rowwise() %>%
mutate_all(funs(str_squish(.))) %>%
ungroup()
df
# A tibble: 2 x 2
a b
<chr> <chr>
1 aZe aze s 12 12
2 wxc s aze 34e e4
str_squish
не видаляє всі пробіли. Він просто обрізає та замінює декілька пробілів для одного.
Таким чином ви можете видалити всі пробіли з усіх змінних символів у вашому кадрі даних. Якщо ви хочете вибрати лише деякі змінні, використовуйте mutate
або mutate_at
.
library(dplyr)
library(stringr)
remove_all_ws<- function(string){
return(gsub(" ", "", str_squish(string)))
}
df<-df %>% mutate_if(is.character, remove_all_ws)