Як видалити всі пробіли з рядка?


Відповіді:


258

Загалом, ми хочемо, щоб рішення було векторизованим, тому ось кращий тестовий приклад:

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

Базовий R підхід: 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

2
@Aniko. Чи є причина, яку ви використали фіксованою = ІСТИНА?
IRTFM

2
@DWin Імовірно, це швидше, якщо R знає, що йому не потрібно посилатися на регулярний вираз. У цьому випадку це насправді не має ніякого значення, я просто звикла це робити.
Аніко

Чи є різниця між "[[:space:]]"і "\\s"?
Sacha Epskamp

5
якщо ви перевірите на flyordie.sin.khk.be/2011/05/04/day-35-replacing-characters або просто введіть? regex, то ви побачите, що [: space:] використовується для "символів пробілу: вкладка, новий рядок , вертикальна вкладка, канал форми, повернення каретки та пробіл. " Це набагато більше, ніж простору
сер Ксилем

1
@Aniko Сподіваємось, ви не заперечуєте проти великої редакції. Оскільки це питання користується великою популярністю, відповідь виглядало так, що відповідь потрібно було більш ретельною.
Річі Коттон

18

Я щойно дізнався про пакет "stringr" для видалення пробілів з початку та кінця рядка з str_trim (, side = "обидва"), але він також має функцію заміни, щоб:

a <- " xx yy 11 22 33 " 
str_replace_all(string=a, pattern=" ", repl="")

[1] "xxyy112233"

3
Пакет stringr не працює добре при кожному кодуванні. пакет stringi - краще рішення, для отримання додаткової інформації перевірити github.com/Rexamine/stringi
bartektartanus

8

Зверніть увагу, що написані вище душі видаляють лише простір. Якщо ви хочете також видалити вкладку або використовувати новий рядок stri_replace_all_charclassз stringiпакета.

library(stringi)
stri_replace_all_charclass("   ala \t  ma \n kota  ", "\\p{WHITE_SPACE}", "")
## [1] "alamakota"

4
stringiпакет зараз на CRAN, насолоджуйтесь! :)
bartektartanus

1
Ця команда вище невірна. Правильний шлях - stri_replace_all_charclass ("ala \ t ma \ n kota", "\\ p {WHITE_SPACE}", "")
Лукас Фортіні

5
Після використання в stringiпротягом декількох місяців , і тепер бачив / дізналися , наскільки потужним і ефективним воно, воно стало моїм йти до пакету для строкових операцій. Ви, хлопці, зробили з цим приголомшливу роботу.
Багатий сценарій

7

Використовуйте [[:blank:]]для порівняння будь-яких видів горизонтальних символів white_space.

gsub("[[:blank:]]", "", " xx yy 11 22  33 ")
# [1] "xxyy112233"


4

Функція str_squish()з пакета stringrtidyverse виконує магію!

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

4
Будь ласка, не посилайтеся на код. Додайте її до тексту тексту своєї відповіді та поясніть тут, щоб надати відповіді більш довгострокове значення.
R Баласубраманіан

Дякуємо @RBalasubramanian за те, що нагадав мені цю інструкцію. Я буду дотримуватися цього в майбутньому.
damianooldoni

Я не бачу, як це відповідає на питання. str_squishне видаляє всі пробіли. Він просто обрізає та замінює декілька пробілів для одного.
Кропива

0

Таким чином ви можете видалити всі пробіли з усіх змінних символів у вашому кадрі даних. Якщо ви хочете вибрати лише деякі змінні, використовуйте 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)

-1

З бібліотеки stringr ви можете спробувати це:

  1. Видаліть послідовні заготовки
  2. Видаліть заповнення

    бібліотека (стрингер)

                2.         1.
                |          |
                V          V
    
        str_replace_all(str_trim(" xx yy 11 22  33 "), " ", "")
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.