Como remover todo o espaço em branco de uma string?

152

Então " xx yy 11 22 33 "se tornará "xxyy112233". Como posso conseguir isso?

waanders
fonte

Respostas:

258

Em geral, queremos uma solução vetorizada, então aqui está um exemplo de teste melhor:

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

A abordagem R básica: gsub

gsubsubstitui todas as instâncias de uma string ( fixed = TRUE) ou expressão regular ( fixed = FALSE, o padrão) por outra string. Para remover todos os espaços, use:

gsub(" ", "", x, fixed = TRUE)
## [1] "xy"                            "←→"             
## [3] "\t\n\r\v\fx\t\n\r\v\fy\t\n\r\v\f" NA 

Como DWin observou, neste caso fixed = TRUE não é necessário, mas fornece um desempenho um pouco melhor, pois a correspondência de uma sequência fixa é mais rápida que a de uma expressão regular.

Se você deseja remover todos os tipos de espaço em branco, use:

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:]"é um grupo de expressão regular específico de R que corresponde a todos os caracteres de espaço. \sé uma expressão regular independente da linguagem que faz a mesma coisa.


A stringrabordagem: str_replace_allestr_trim

stringrfornece mais wrappers legíveis por humanos em torno das funções R básicas (embora em dezembro de 2014, a versão de desenvolvimento tenha uma ramificação construída em cima stringi, mencionada abaixo). Os equivalentes dos comandos acima, usando [ str_replace_all][3], são:

library(stringr)
str_replace_all(x, fixed(" "), "")
str_replace_all(x, space(), "")

stringrtambém possui uma str_trimfunção que remove apenas os espaços em branco iniciais e finais.

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      

A stringiabordagem: stri_replace_all_charclassestri_trim

stringié construído sobre a biblioteca ICU independente da plataforma e possui um amplo conjunto de funções de manipulação de strings. o equivalentes dos itens acima são:

library(stringi)
stri_replace_all_fixed(x, " ", "")
stri_replace_all_charclass(x, "\\p{WHITE_SPACE}", "")

Aqui "\\p{WHITE_SPACE}"está uma sintaxe alternativa para o conjunto de pontos de código Unicode considerados como espaço em branco, equivalente a "[[:space:]]","\\s" e space(). Para substituições de expressões regulares mais complexas, também existe stri_replace_all_regex.

stringitambém possui funções de apara .

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
Aniko
fonte
2
@Aniko. Existe um motivo pelo qual você usou fixed = TRUE?
IRTFM 13/05
2
@DWin Supostamente é mais rápido se R souber que não precisa invocar o material de expressão regular. Nesse caso, realmente não faz diferença, eu apenas tenho o hábito de fazê-lo.
Aniko
Existe uma diferença entre "[[:space:]]"e "\\s"?
Sacha Epskamp
5
se você verificar flyordie.sin.khk.be/2011/05/04/day-35-replacing-characters ou apenas digitar? regex, verá que [: space:] é usado para "Space characters: tab, newline , guia vertical, avanço de página, retorno de carro e espaço ". Isso é muito mais do que o espaço sozinho
Sir Ksilem
1
@ Aniko Espero que você não se importe com a grande edição. Como essa pergunta é altamente popular, parecia que a resposta precisava ser mais completa.
Richie Cotton
18

Acabei de aprender sobre o pacote "stringr" para remover o espaço em branco do início e do fim de uma string com str_trim (, side = "both"), mas também possui uma função de substituição para que:

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

[1] "xxyy112233"
JollyRoger
fonte
3
O pacote stringr não funciona bem com todas as codificações. pacote Stringi é melhor solução, para mais informações cheque github.com/Rexamine/stringi
bartektartanus
8

Observe que as almas escritas acima removem apenas o espaço. Se você quiser também para remover guia ou nova linha uso stri_replace_all_charclassdo stringipacote.

library(stringi)
stri_replace_all_charclass("   ala \t  ma \n kota  ", "\\p{WHITE_SPACE}", "")
## [1] "alamakota"
bartektartanus
fonte
4
stringipacote já está no CRAN, divirta-se! :)
bartektartanus
1
Este comando acima está incorreto. O caminho certo é stri_replace_all_charclass ("ala \ t ma \ n kota", "\\ p {WHITE_SPACE}", "")
Lucas Fortini
5
Depois de usar stringipor alguns meses e ver / aprender o quão poderoso e eficiente é, tornou-se meu pacote obrigatório para operações de string. Vocês fizeram um trabalho incrível com isso.
Rich Scriven
7

Use [[:blank:]]para corresponder a qualquer tipo de caracteres de espaço em branco horizontal.

gsub("[[:blank:]]", "", " xx yy 11 22  33 ")
# [1] "xxyy112233"
Avinash Raj
fonte
6
x = "xx yy 11 22 33"

gsub(" ", "", x)

> [1] "xxyy112233"
ZWL
fonte
4

A função str_squish()do pacote stringrtidyverse faz a mágica!

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
damianooldoni
fonte
4
Por favor, não vincule ao código. Adicione-o no corpo do texto da sua resposta e explique-o aqui, para fornecer um valor mais longo a sua resposta.
R Balasubramanian
Obrigado @RBalasubramanian por me lembrar desta diretriz. Vou segui-lo no futuro.
Damianoldoni
Não vejo como isso responde à pergunta. str_squishnão remove todos os espaços. Apenas apara e substitui vários espaços por um.
Nettle
0

Dessa forma, você pode remover todos os espaços de todas as variáveis ​​de caracteres no seu quadro de dados. Se você preferir escolher apenas algumas das variáveis, use mutateou 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)
NinaOtopal
fonte
-1

Na biblioteca stringr, você pode tentar o seguinte:

  1. Remova espaços em branco consecutivos
  2. Remover preenchimento em branco

    biblioteca (stringr)

                2.         1.
                |          |
                V          V
    
        str_replace_all(str_trim(" xx yy 11 22  33 "), " ", "")
Data Jules
fonte