如何从R中的数据/转义特殊字符中去除美元符号($)?

如何从R中的数据/转义特殊字符中去除美元符号($)?,r,escaping,R,Escaping,我一直在使用gsubtoreplace、replacement、myvector来清除R中的数据。虽然这对逗号等有用,但删除$没有任何效果。所以如果我做gsub$,myvector,所有的美元符号都保持不变 我想这是因为$是R中的一个特殊字符。我尝试将其转义为\$,但同样的结果没有效果。我找不到关于在R中转义特殊字符的资源 显然,我应该在预处理中这样做。但我想知道,是否有人知道如何在R b中的特殊角色转义,或者直接摆脱R中讨厌的$。对于科学而言。转义字符有时会很痛苦,但将其放在方括号中使其成为字

我一直在使用gsubtoreplace、replacement、myvector来清除R中的数据。虽然这对逗号等有用,但删除$没有任何效果。所以如果我做gsub$,myvector,所有的美元符号都保持不变

我想这是因为$是R中的一个特殊字符。我尝试将其转义为\$,但同样的结果没有效果。我找不到关于在R中转义特殊字符的资源


显然,我应该在预处理中这样做。但我想知道,是否有人知道如何在R b中的特殊角色转义,或者直接摆脱R中讨厌的$。对于科学而言。

转义字符有时会很痛苦,但将其放在方括号中使其成为字符类有助于:

> gsub("[$]","",c("$100","ta$ty"))
[1] "100"  "taty"

你必须逃避它两次,第一次是R,第二次是正则表达式

gsub('\\$', '', c("a$a", "bb$"))
[1] "aa" "bb"
有关引用和转义的详细信息,请参见?引号。

使用fixed=TRUE:

那么你就不必担心任何特殊的角色了。在stringr中,实现方式略有不同:

library(stringr)
str_replace_all(c("$100","ta$ty"), fixed("$"), "")

感谢DiggyF和James的例子

如果在一组数据列中有$后跟数字,例如$400000,那么有一种更简单的方法对我来说非常有效。 数据%>% 5:6变异,解析数字 其中5:6为数据列编号

library(stringr)
str_replace_all(c("$100","ta$ty"), fixed("$"), "")