3

次の問題があります。

ひもを回したい

> a<-paste('x=col1,y=col2,fill=col3')

aes_string が次のように受け入れる形式に: x='col1',y='col2',fill='col3'

これは関数の一部です:

>fun<-function(data,aes.string=''){
aes_mapping <- aes_string(aes.string)
p <- ggplot(df.data,mapping=aes_mapping )
p <- p + geom_point()
return(p)
}

私が電話したら

> fun(df.sam,a)
> Error in parse(text = x) : <text>:1:7: unexpected ',' 
1: x=col1,
        ^

>dput(df.sam)
structure(list(col1 = c(1.99340197320543, 4.96225966782141, 1.42191486886353, 
5.41389048265218, 1.48427007201488, 3.43977166739915, 2.43656907238302, 
2.863856404804, 2.71825401870433, 3.17825292487285), col2 = c(76.2306398916608, 
5.89150952248784, 38.634046526178, 28.3032368687166, 14.7025137552809, 
9.11163890447616, 46.3416263715291, 31.9935691220763, 49.799629992835, 
24.5153013442625), col3 = c(152, 600, 305, 375, 305, 300, 229, 
330, 229, 300)), .Names = c("col1", "col2", "col3"), row.names = c(NA, 
10L), class = "data.frame")

どんな助けでも大歓迎です!

4

1 に答える 1

2

Use character string as function argumentから:

ただし、この場合、aes_string文字列を渡さないため必要ありません (no ")。の誤字脱字も修正しましたfun()

fun<-function(data,aes.string=''){
  aes_mapping <- eval(parse(text = paste("aes(", a, ")")))
  p <- ggplot(data,mapping=aes_mapping )
  p <- p + geom_point()
  return(p)
}

a<-paste('x=col1,y=col2,fill=col3')


fun(df.sam,a)

ここに画像の説明を入力

于 2013-11-07T13:36:39.187 に答える