如何从R中的数据/转义特殊字符中去除美元符号($)?
我一直在使用如何从R中的数据/转义特殊字符中去除美元符号($)?,r,escaping,R,Escaping,我一直在使用gsub(“toreplace”,“replacement”,myvector)清除R中的数据。虽然这对逗号等有用,但删除“$”没有效果。因此,如果我做了gsub(“$”,“”,myvector)所有的美元符号都保持不变 我认为这是因为$是R中的一个特殊字符。我尝试将其转义为“\$”,但结果相同(没有效果)。我找不到关于在R中转义特殊字符的资源 显然,我应该在预处理中这样做。但我想知道是否有人知道如何a)转义R中的特殊字符b)直接摆脱R中讨厌的$。对于科学而言。转义字符有时会很痛苦,
gsub(“toreplace”,“replacement”,myvector)
清除R中的数据。虽然这对逗号等有用,但删除“$”
没有效果。因此,如果我做了gsub(“$”,“”,myvector)
所有的美元符号都保持不变
我认为这是因为$
是R中的一个特殊字符。我尝试将其转义为“\$”
,但结果相同(没有效果)。我找不到关于在R中转义特殊字符的资源
显然,我应该在预处理中这样做。但我想知道是否有人知道如何a)转义R中的特殊字符b)直接摆脱R中讨厌的
$
。对于科学而言。转义字符有时会很痛苦,但将其放在方括号中(使其成为字符类)有助于:
> gsub("[$]","",c("$100","ta$ty"))
[1] "100" "taty"
你必须逃避它两次,第一次是R,第二次是正则表达式
gsub('\\$', '', c("a$a", "bb$"))
[1] "aa" "bb"
有关引用和转义的详细信息,请参见
?Quotes
。使用fixed=TRUE
:
gsub('$', '', c("a$a", "bb$"), fixed = TRUE)
那么你就不必担心任何特殊的角色了。在stringr
中,实现方式略有不同:
library(stringr)
str_replace_all(c("$100","ta$ty"), fixed("$"), "")
感谢DiggyF和James的例子 如果在一组数据列中有$后跟数字(例如$400000),有一种更简单的方法对我来说很有吸引力。 数据%>% 在(5:6,解析编号)处变异 其中5:6为数据列编号