提问人:waanders 提问时间:5/13/2011 最后编辑:oguz ismailwaanders 更新时间:7/22/2021 访问量:429800
如何从字符串中删除所有空格?
How to remove all whitespace from a string?
答:
一般来说,我们想要一个矢量化的解决方案,所以这里有一个更好的测试示例:
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 年 12 月,开发版本有一个构建在 之上的分支,如下所述)。使用 [,上述命令的等效项是: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=“both”) 删除字符串开头和结尾的空格,但它也具有替换功能,以便:
a <- " xx yy 11 22 33 "
str_replace_all(string=a, pattern=" ", repl="")
[1] "xxyy112233"
评论
请注意,上面写的 soultions 仅删除空格。如果您还想从包中删除制表符或换行符,请使用。stri_replace_all_charclass
stringi
library(stringi)
stri_replace_all_charclass(" ala \t ma \n kota ", "\\p{WHITE_SPACE}", "")
## [1] "alamakota"
评论
stringi
套餐现在在CRAN上,尽情享受吧!:)
stringi
用于匹配任何类型的横white_space字符。[[:blank:]]
gsub("[[:blank:]]", "", " xx yy 11 22 33 ")
# [1] "xxyy112233"
x = "xx yy 11 22 33"
gsub(" ", "", x)
> [1] "xxyy112233"
tidyverse软件包中的功能具有魔力!str_squish()
stringr
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
从stringr库中,你可以试试这个:
- 删除连续的填充空白
删除填充空白
库(串口)
2. 1. | | V V str_replace_all(str_trim(" xx yy 11 22 33 "), " ", "")
评论
可以考虑另一种方法
library(stringr)
str_replace_all(" xx yy 11 22 33 ", regex("\\s*"), "")
#[1] "xxyy112233"
\\s:匹配空格、制表符、垂直制表符、换行符、表单进取符、回车符
*:至少匹配 0 次
评论
income<-c("$98,000.00 ", "$90,000.00 ", "$18,000.00 ", "")
使用该功能后删除空间。.00
trimws()
income<-trimws(income)
上一个:如何测量字符串之间的相似性?
下一个:将数据框字符串列拆分为多个列
评论