- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 df:
> head(giftByDay)
giftDate gift yr mon day
1 2009-07-01 100.00 2009 7 1
2 2009-07-03 300.00 2009 7 3
3 2009-07-06 470.00 2009 7 6
4 2009-07-07 7436.66 2009 7 7
5 2009-07-09 50.00 2009 7 9
6 2009-07-11 25.00 2009 7 11
它有 3 年的数据(财政年度截至 6 月 30 日),我试图将所有 3 个数据放在一个图中,作为 3 个单独的线来比较逐年表现。另外,我尝试将美元放在 y 轴上,将 MM-DD 放在 x 轴上。
我根据年份将其分为 3 部分:
> yr2009 <- subset(giftByDay, giftByDay$giftDate >= "2009-07-01" & giftByDay$giftDate < "2010-07-01")
> yr2010 <- subset(giftByDay, giftByDay$giftDate >= "2010-07-01" & giftByDay$giftDate < "2011-07-01")
> yr2011 <- subset(giftByDay, giftByDay$giftDate >= "2011-07-01" & giftByDay$giftDate < "2012-07-01")
接下来我创建用于绘图的动物园对象:
> yr2009$d2 <- format(as.Date(yr2009$giftDate), "%m-%d")
> x1 <- zoo(yr2009$gift, yr2009$d2)
> yr2010$d2 <- format(as.Date(yr2010$giftDate), "%m-%d")
> x2 <- zoo(yr2010$gift, x2.Date)
> yr2011$d2 <- format(as.Date(yr2011$giftDate), "%m-%d")
> x3 <- zoo(yr2011$gift, x3.Date)
当我尝试实际绘制它时,问题就开始了:
> plot(x1, type="l", col=1)
Error in plot.window(...) : need finite 'xlim' values
In addition: Warning messages:
1: In xy.coords(x, y, xlabel, ylabel, log) : NAs introduced by coercion
2: In min(x) : no non-missing arguments to min; returning Inf
3: In max(x) : no non-missing arguments to max; returning -Inf
> points(x2, type="l", col=2)
Warning message:
In xy.coords(x, y) : NAs introduced by coercion
> points(x3, type="l", col=3)
Warning message:
In xy.coords(x, y) : NAs introduced by coercion
对象中实际上有东西:
> head(x1)
01-01 01-04 01-05 01-08 01-11 01-13
15.0 125.0 1000.0 6350.0 200.0 291281.1
但我不明白为什么它不会绘制。有什么建议吗?
编辑:
> giftByDayList <- split(as.xts(giftByDay), "years")
Error in as.POSIXlt.character(x, tz, ...) :
character string is not in a standard unambiguous format
> class(giftByDay$giftDate)
[1] "character"
我不确定是什么原因导致此错误。
编辑2:
> gbd <- zoo(giftByDay)
> gbd <- as.xts(gbd)
Error in xts(coredata(x), order.by = order.by, frequency = frequency, :
order.by requires an appropriate time-based object
> giftByDayList <- split(as.xts(gbd), "years")
Error in xts(coredata(x), order.by = order.by, frequency = frequency, :
order.by requires an appropriate time-based object
编辑3:
> giftByDayList <- split(xts(giftByDay[,-1],as.Date(giftByDay$giftDate)), "years")
> giftByDayList <- lapply(giftByDayList, toyear, 2011)
Error in `index<-.xts`(`*tmp*`, value = list(sec = c(0, 0, 0, 0, 0, 0, :
unsupported ‘index’ index type of class ‘POSIXt’unsupported ‘index’ index type of class ‘POSIXlt’
> str(giftByDayList )
List of 3
$ :An ‘xts’ object from 2009-07-01 to 2009-12-31 containing:
Data: num [1:89, 1:4] 100 300 470 7437 50 ...
- attr(*, "dimnames")=List of 2
..$ : NULL
..$ : chr [1:4] "gift" "yr" "mon" "day"
Indexed by objects of class: [Date] TZ:
xts Attributes:
NULL
$ :An ‘xts’ object from 2010-01-01 to 2010-12-31 containing:
Data: num [1:213, 1:4] 15 125 1000 6350 200 ...
- attr(*, "dimnames")=List of 2
..$ : NULL
..$ : chr [1:4] "gift" "yr" "mon" "day"
Indexed by objects of class: [Date] TZ:
xts Attributes:
NULL
$ :An ‘xts’ object from 2011-01-02 to 2011-10-26 containing:
Data: num [1:189, 1:4] 1500 235 1000 18154 10 ...
- attr(*, "dimnames")=List of 2
..$ : NULL
..$ : chr [1:4] "gift" "yr" "mon" "day"
Indexed by objects of class: [Date] TZ:
xts Attributes:
NULL
>
最佳答案
1) data.frame 解决方案。尝试这个。我们设置一些测试数据,然后计算会计年度并重新确定转换语句中每个日期的基准。最后,我们按会计年度绘制了赠与日期与重新调整日期的关系。请注意,它实际上只有两个语句,一个用于变换,一个用于绘图。
## set up test data
giftDate <- seq(as.Date("2009-07-01"), length = 36, by = "month")
giftByDay <- data.frame(giftDate, gift = 1:36,
yr = as.numeric(format(giftDate, "%Y")),
mon = as.numeric(format(giftDate, "%m")),
day = as.numeric(format(giftDate, "%d")))
## now that we have test data, calculate fiscalyear, rebase each date to 1999-2000
## and plot
giftByDay <- transform(giftByDay, fiscalyear = yr + (mon > 6),
Date = as.Date(paste(2000 - (mon > 6), mon, day, sep = "-")))
library(lattice)
xyplot(gift ~ Date, giftByDay, group = fiscalyear, type = "o", auto.key = TRUE)
编辑:
在下面添加了动物园解决方案。
2)动物园解决方案。在这种情况下,解决方案并不比仅使用数据框简单,尽管如果 z
的特定形式可用于其他计算,它可能会具有优势:
library(zoo)
library(lattice)
giftByDay <- transform(giftByDay, fiscalyear = yr + (mon > 6))
z <- read.zoo(giftByDay[2:6], index = 2:4, split = 5, FUN = function(y, m, d)
as.Date(paste(2000 - (m > 6), m, d, sep = "-")))
xyplot(z, screen = 1, col = 1:3, type = "o", auto.key = TRUE, ylab = "Gift")
这是动物园对象 z
的样子:
> z
2010 2011 2012
1999-07-01 1 13 25
1999-08-01 2 14 26
1999-09-01 3 15 27
1999-10-01 4 16 28
1999-11-01 5 17 29
1999-12-01 6 18 30
2000-01-01 7 19 31
2000-02-01 8 20 32
2000-03-01 9 21 33
2000-04-01 10 22 34
2000-05-01 11 23 35
2000-06-01 12 24 36
关于R Zoo绘制多年数据重叠的图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7930875/
我学习 SDL 二维编程已有一段时间了,现在我想创建一个结合使用 SDL 和 OpenGL 的程序。我是这样设置的: SDL_Init(SDL_INIT_VIDEO); window = SDL_Cr
尝试查找可在地块中使用的不同类型项目的列表 来自不同样本的投影类型: projection = list(type = "equirectangular") projection = list(typ
我正在尝试使用 Java Graphics API 绘制 GIF,但无法使用下面的代码成功绘制 GIF。仅绘制 GIF 的第一张图像或缩略图,但不播放。 public void paintCompon
我目前正在使用 JFrame 并尝试绘制一个矩形,但我不知道如何执行代码 paint(Graphics g),如何获取 Graphics 对象? package com.raggaer.frame;
这个领域的新手,希望得到一些帮助。 我有一个"Missile.java" 类,我在那里画东西。我想绘制一个 ImageView,我正在使用以下代码: ImageView v = (ImageView)
下面列出了圆形的例子 这是我的 JavaScript 代码。 最佳答案 假设您的 randomColor 是正确的,您只需要: 从 canvas.onclick 中移除 context.clearR
我在绘制和缩放 ImageView 时遇到问题。请帮帮我.. 当我画一些东西然后拖动或缩放图像时 - 绘图保留在原处,如您在屏幕截图中所见。而且我只需要简单地在图片上绘图,并且可以缩放和拖动这张图片。
我们可以在形式之外绘制图像和文本...我的意思是在字面上... 我知道问这个问题很愚蠢但是我们能不能... 最佳答案 您可以通过创建表单并将其 TransparentColor 属性设置为背景色来“作
我在绘制/布局期间收到 3 个对象分配警告 super.onDraw(canvas); canvas.drawColor(Color.WHITE); Paint textPaint = new Pai
我有一个示例时间序列数据框: df = pd.DataFrame({'year':'1990','1991','1992','1993','1994','1995','1996',
我试图想出一种简洁的方法来绘制 R 数据框中所有列的 GridView 。问题是我的数据框中既有离散值又有数值。为简单起见,我们可以使用 R 提供的名为 iris 的示例数据集。我会使用 par(mf
我有一个由 10 列和 50 行组成的 data.frame。我使用 apply 函数逐列计算密度函数。现在我想绘制我一次计算的密度。 换句话说,而不是绘图... plot(den[[1]]) plo
我想知道我们如何才能在第一个和第二个组件之外绘制个人,如下所示: 最佳答案 这可能有效: pc.cr <- princomp(USArrests, cor = TRUE) pairs(pc.cr$lo
我是Pandas和matplotlib的新手,想绘制此DataFrame season won team matches pct_won 0 20
我正在尝试为 distplot 子图编写一个 for 循环。 我有一个包含许多不同长度列的数据框。 (不包括 NaN 值) fig = make_subplots( rows=len(asse
我想创建一个具有密度的 3d 图。 我使用函数 density 首先为特定的 x 值创建一个二维图,然后该函数创建密度并将它们放入 y 变量中。现在我有第二组 x 值并将其再次放入密度函数中,然后我得
全部, 我一直在研究全局所有 MTB 步道的索引。我是 Python 人,所以对于所有涉及的步骤,我都尝试使用 Python 模块。 我能够像这样从 OSM 立交桥 API 中获取关系: from O
我正在使用 e1071 包中的支持向量机对我的数据进行分类,并希望可视化机器实际如何进行分类。但是,在使用 plot.svm 函数时,出现无法解决的错误。 脚本: library("e1071") d
我制作了以下图表,它是使用 xts 对象创建的。 我使用的代码很简单 plot(graphTS1$CCLL, type = "l", las = 2, ylab = "(c)\nCC for I
在绘制状态图时,您如何知道哪些状态放在框中,哪些状态用于转换箭头?我注意到转换也是状态。 我正在查看 this page 上的图 1 : 最佳答案 转换不是状态。转换是将对象从一种状态移动到下一种状态
我是一名优秀的程序员,十分优秀!