r - 根据水年创建日指数

标签 r date time

我正在处理水文数据,我需要水年。我已经根据之前在此论坛上发布的功能成功创建了一个水年专栏。我想要的是随行water day范围从 1-365(闰年为 366)以匹配水年序列。请注意,水年是由它结束的日历年指定的。例如,2010年水年从2009年10月1日开始,到2010年9月30日结束。

基本上,我想要一个从 1-365(闰年为 366)开始的列,每当日期达到每年的 10 月 1 日。

我的数据集范围从 1950 年到 2099 年,所以我需要某种方式来自动化这个过程。这个问题的闰年部分给我带来了麻烦。

我在下面提供了代码来创建数据集。

# Create a data_set with datetime, year, month, day, jd, wtr_yr

library(lubridate)

datetime <- seq(as.Date("1950/1/1"), as.Date("2099/12/31"), by = "day")
year <- year(datetime)
month <- month(datetime)
day <- day(datetime)
julian_day <- yday(datetime)

# make dataframe with all time components
datetime_dataframe <- data.frame(datetime, year, month, day, julian_day)

# Create function to derive water year. Credit goes to Caner and MrFlick.

wtr_yr <- function(dates, start_month=10) {
  # Convert dates into POSIXlt
  dates.posix = as.POSIXlt(dates)
  # Year offset
  offset = ifelse(dates.posix$mon >= start_month - 1, 1, 0)
  # Water year
  adj.year = dates.posix$year + 1900 + offset
  # Return the water year
  adj.year
}

#  Use fn to add water year to the dataframe
datetime_dataframe$wtr_yr <-wtr_yr(datetime_dataframe$datetime)

head(datetime_dataframe)

最佳答案

这是您的一种可能方法。我从 1949-10-01 创建了日期序列。我加了 water.year第一的。任何具有月 == 9 和天 == 30 的行都被标记并标记为 1。其余的变为 0。使用此列,我为水年创建了一个分组变量。 cumsum(c(F, diff(water.year) < 0))正在做这项工作。一旦我有了分组变量,我就创建了日期序列。我在下面留下了最终结果的一部分。

library(dplyr)
library(lubridate)

mydata <- data.frame(date = seq(as.Date("1949-10-01"),as.Date("2099-12-31"), by = "day")) %>%
          mutate(year = year(date),
                 month = month(date),
                 day = day(date),
                 julian_day = yday(date),
                 water.year = if_else(month == 9 & day == 30, 1, 0))

mydata %>%
group_by(water.year = cumsum(c(F, diff(water.year) < 0))) %>%
mutate(water.day = 1:n())

         date year month day julian_day water.year water.day
1  1952-09-01 1952     9   1        245          2       337
2  1952-09-02 1952     9   2        246          2       338
3  1952-09-03 1952     9   3        247          2       339
28 1952-09-28 1952     9  28        272          2       364
29 1952-09-29 1952     9  29        273          2       365
30 1952-09-30 1952     9  30        274          2       366

关于r - 根据水年创建日指数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48123049/

相关文章:

c - 我可以使用 C 中的什么函数来单独获取与时间分开的日期?

r - 根据增加或减少值更改点的颜色

r - 有没有办法在 R 中为每个顶点分配多个标签

r - 如何在我的数据框中将所有数字列转换为字符类型?

php mysql - phpmyadmin 日期

php - 棘手的mysql计算日期范围内每一天的出现次数

java - Android - 时间不更新

r - 行之间的条件时间差。研发&dplyr/data.table

java - 将一种格式的字符串日期转换为另一种格式的日期对象

r - 将时间戳(开始、结束)转换为时间序列数据。 align.time() 和 colname 错误