我的数据DT具有以下结构:
structure(list(Ticker = c("MSDLWI Index", "MSDLWI Index", "MSDLWI Index", "MSDLWI Index","MSDLWI Index", "MSDLWI Index", "NDLEACWF Index", "NDLEACWF Index", "NDLEACWF Index","NDLEACWF Index", "NDLEACWF Index", "NDLEACWF Index"), Date = structure(c(-1L, 89L, 180L, 272L, 364L, 454L, 15705L, 15793L, 15884L, 15978L, 16070L, 16136L), class = c("IDate", "Date")), Value = c(NA, -0.02925, -0.180118465104301, 0.124488001005151, 0.0497217814923236,0.0966385660152425, 0.0323951658690891, 0.0842289682913797, 0.00992717655157427, 0.0631103139013451, 0.0782204344979787, 0.00855027196875335)), .Names =c("Ticker", "Date", "Value"), row.names = c(NA, -12L),class=c("data.table","data.frame"))
Run Code Online (Sandbox Code Playgroud)
头(DT,3)
Ticker Date Value
1: MSDLWI Index 1969-12-31 NA
2: MSDLWI Index 1970-03-31 -0.0292500
3: MSDLWI Index 1970-06-30 -0.1801185
Run Code Online (Sandbox Code Playgroud)
但是,列名称可能是volatile,因此我尝试在ggplot调用中对它们进行参数化:
var.col="Ticker"
ggplot(DT, aes(x=Date, y=Value, colour=eval(parse(text=var.col)))) + geom_line()
Run Code Online (Sandbox Code Playgroud)
http://i.stack.imgur.com/H3tbN.png
在情节图例中,如何显示Ticker而不是eval(parse(text=var.col))?
时髦的eval(parse())生意没有理由:
ggplot(DT, aes_string(x="Date", y="Value", colour=var.col)) +
geom_line()
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1040 次 |
| 最近记录: |