首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用bigquery / bigrquery和dbplyr?(相当于卢布酸::周)

使用bigquery / bigrquery和dbplyr?(相当于卢布酸::周)
EN

Stack Overflow用户
提问于 2019-12-06 02:11:23
回答 1查看 255关注 0票数 0

我试图使用bigrquery和dbplyr获取week of the year that a date corresponds to (即与lubridate::week()相同,即

代码语言:javascript
复制
library(lubridate)
library(dbplyr)
library(bigrquery)

week("2015-08-11")   
# [1] 32

但我使用的是bigrquerydbplyr

到目前为止我尝试过的

使用lubridate::week()我看到了

代码语言:javascript
复制
transactions %>% 
  select(item, date) %>% 
  mutate(week = week(date)) %>%
  collect()
Error: Function not found: week at [1:30] [invalidQuery]

所以我尝试了这个自制的解决方案

代码语言:javascript
复制
transactions %>% 
  select(item, date) %>%
  mutate(week = strftime(date, format = "%V")) %>% 
  collect()

Error: Syntax error: Expected ")" but got keyword AS at [1:54] [invalidQuery]
In addition: Warning message:
  Named arguments ignored for SQL strftime 

以及另一个(相当丑陋的)自制的解决方案

代码语言:javascript
复制
transactions %>% 
  select(item, date) %>% 
  mutate(week = as.numeric((as.Date(date) - as.Date(paste0(substr(date, 1, 4), "-01-01"))), units="days") %/% 7) %>% 
  collect()

Error in as.numeric((as.Date(date) - as.Date(paste0(substr(date, 1,  : 
unused argument (units = "days")

但是我似乎找不到一种使用bigquery和dbplyr获取周数的方法。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-06 02:20:50

我似乎找不到一种使用BigQuery

获取周数的方法

看起来您正在寻找下面的BigQuery标准SQL函数

代码语言:javascript
复制
EXTRACT(WEEK FROM date)    

您可以使用周或周(< WEEKDAY>)或ISOWEEK

请参阅有关日期部分的更多信息,这里是https://cloud.google.com/bigquery/docs/reference/standard-sql/date_functions#extract

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59205883

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档