如何从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为数据列编号