Odpowiedzi:
Ogólnie rzecz biorąc, chcemy rozwiązania wektoryzowanego, więc oto lepszy przykład testowy:
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
zamienia wszystkie wystąpienia ciągu ( fixed = TRUE
) lub wyrażenia regularnego ( fixed = FALSE
domyślne) na inny ciąg. Aby usunąć wszystkie spacje, użyj:
gsub(" ", "", x, fixed = TRUE)
## [1] "xy" "←→"
## [3] "\t\n\r\v\fx\t\n\r\v\fy\t\n\r\v\f" NA
Jak zauważył DWin, w tym przypadku fixed = TRUE
nie jest to konieczne, ale zapewnia nieco lepszą wydajność, ponieważ dopasowanie ustalonego ciągu jest szybsze niż dopasowanie wyrażenia regularnego.
Jeśli chcesz usunąć wszystkie rodzaje białych znaków, użyj:
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:]"
jest specyficzną dla języka R grupą wyrażeń regularnych pasującą do wszystkich znaków spacji. \s
jest niezależnym od języka wyrażeniem regularnym, które robi to samo.
stringr
Podejście: str_replace_all
astr_trim
stringr
zapewnia bardziej czytelne dla człowieka otoki wokół podstawowych funkcji języka R (chociaż od grudnia 2014 r. wersja rozwojowa ma wbudowaną gałąź stringi
, o której mowa poniżej). Odpowiednikami powyższych poleceń, używając [ str_replace_all][3]
, są:
library(stringr)
str_replace_all(x, fixed(" "), "")
str_replace_all(x, space(), "")
stringr
posiada również str_trim
funkcję, która usuwa tylko początkowe i końcowe spacje.
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
Podejście: stri_replace_all_charclass
astri_trim
stringi
jest zbudowany na niezależnej od platformy bibliotece ICU i posiada obszerny zestaw funkcji manipulowania ciągami znaków. W równoważniki powyżej wymienionych związków są:
library(stringi)
stri_replace_all_fixed(x, " ", "")
stri_replace_all_charclass(x, "\\p{WHITE_SPACE}", "")
Tutaj "\\p{WHITE_SPACE}"
jest alternatywną składnię dla zbioru punktów kodowych Unicode uznawanych za białe znaki, co odpowiada "[[:space:]]"
, "\\s"
a space()
. W przypadku bardziej złożonych zamiany wyrażeń regularnych istnieje również stri_replace_all_regex
.
stringi
posiada również funkcje przycinania .
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:]]"
i "\\s"
?
Właśnie dowiedziałem się o pakiecie „stringr” do usuwania białych znaków z początku i końca ciągu za pomocą str_trim (, side = „both”), ale ma on również funkcję zastępującą, dzięki czemu:
a <- " xx yy 11 22 33 "
str_replace_all(string=a, pattern=" ", repl="")
[1] "xxyy112233"
Zwróć uwagę, że napisane powyżej słowa usuwają tylko spację. Jeśli chcesz również usunąć tabulację lub nową linię, użyj stri_replace_all_charclass
z stringi
pakietu.
library(stringi)
stri_replace_all_charclass(" ala \t ma \n kota ", "\\p{WHITE_SPACE}", "")
## [1] "alamakota"
stringi
pakiet jest teraz na CRAN, ciesz się! :)
stringi
kilku miesiącach używania i zobaczeniu / nauczeniu się, jak potężny i wydajny jest on, stał się moim podstawowym pakietem do operacji na strunach. Wykonaliście z tym świetną robotę.
Służy [[:blank:]]
do dopasowywania dowolnych poziomych znaków białej spacji.
gsub("[[:blank:]]", "", " xx yy 11 22 33 ")
# [1] "xxyy112233"
Funkcja str_squish()
z pakietu stringr
tidyverse robi magię!
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
nie usuwa wszystkich spacji. Po prostu przycina i zastępuje wiele spacji.
W ten sposób możesz usunąć wszystkie spacje ze wszystkich zmiennych znakowych w ramce danych. Jeśli wolisz wybrać tylko niektóre zmienne, użyj mutate
lub 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)
Z biblioteki stringr możesz spróbować tego:
Usuń puste wypełnienie
biblioteka (stringr)
2. 1.
| |
V V
str_replace_all(str_trim(" xx yy 11 22 33 "), " ", "")