精华内容
下载资源
问答
  • 根据给出的时间戳,求出 此时间戳对应的 的时间戳 如 给出这1号00:00:00 的时间戳 给出这周一的00:00:00的时间戳 下面是方法代码 def getAggregateDate(day: Long, timeUnit: String): ...

    1.问题描述:开发中遇到以下需求:
    根据给出的时间戳,求出 此时间戳对应的 年 月 日 周 的时间戳
    如 年 给出这年1号00:00:00 的时间戳
    周 给出这周周一的00:00:00的时间戳
    下面是方法代码

    def getAggregateDate(day: Long, timeUnit: String): Long = {
    
      val date: DateTime = new DateTime(day*1000, DateTimeZone.forID("Asia/Shanghai"))
      val valueTime = timeUnit match {
        case "day" => date.toString("yyyy-MM-dd")
        case "week" => date.withDayOfWeek(1).toString("yyyy-MM-dd")
        case "month" => date.withDayOfMonth(1).toString("yyyy-MM-dd")
        case "year" => date.withDayOfYear(1).toString("yyyy-MM-dd")
      }
      val format = new SimpleDateFormat("yyyy-MM-dd")
      val timeStamp: Long = format.parse(valueTime).getTime
      timeStamp/1000
    }
    展开全文
  • 2017-05-16 18:32:02
    1、周转,全年第n的起止  public function dayFromWeek($week,$year=0){ $year = empty($year)?date('Y'):$year; $year_start = mktime(0,0,0,1,1,$year); // 判断第一天是否为第一的开始 if (1 ==...

    1、周转日,全年第n周的起止日 

    public function dayFromWeek($week,$year=0){
    
        $year = empty($year)?date('Y'):$year;
        $year_start = mktime(0,0,0,1,1,$year);
    
        // 判断第一天是否为第一周的开始
        if (1 == date('W',$year_start)){
            $start = $year_start;//把第一天做为第一周的开始
        }else{
    
            $start = strtotime('next Monday', $year_start);
        }
    
        // 第几周的开始时间
        if (0 == $week){
            $weekday['start'] = strtotime('last Monday', $year_start);
        }elseif (1 == $week){
    
            $weekday['start'] = $start;
        }else{
    
            $weekday['start'] = strtotime('+'.($week-0).' monday',$start);
        }
    
        // 第几周的结束时间
        $weekday['end'] = strtotime('+1 sunday',$weekday['start']);
    
        $weekday['start'] = date("Y-m-d",$weekday['start']);
        $weekday['end'] = date("Y-m-d",$weekday['end']);
        return $weekday;
    }

    2、月起止日

    public function dayFromMonth($month, $year=0){

    $year = empty($year)?date('Y'):$year;
    $month = strlen($month)==2?$month:'0'.$month;
    $startDay = $year.'-'.$month.'-01';

    $endDay = date('Y-m-d', strtotime(date('Y-m-01', strtotime($startDay)) . ' +1 month -1 day'));

    return ['start'=>$startDay, 'end'=>$endDay];
    }

     

    3、月起止周,当月跨过了哪些周

     

    public function weekFromMonth($month, $year=0){

    $day = $this->dayFromMonth($month, $year);

    return ['start'=>date('W',strtotime($day['start'])),'end'=>date('W',strtotime($day['end']))];
    }

    4、第几周在当月的起止日

    public function dayFromWM($week,$month,$year=0){

    $year = empty($year)?date('Y'):$year;
    $year_start = mktime(0,0,0,1,1,$year);
    $year_end = mktime(0,0,0,12,31,$year);

    $month_start = $year.'-'.$month.'-01';
    $month_end = date('Y-m-d', strtotime(date('Y-m-01', strtotime($month_start)) . ' +1 month -1 day'));

    // 判断第一天是否为第一周的开始
    if (intval(date('W',$year_start))===1){
    $start = $year_start;//把第一天做为第一周的开始
    }else{

    $start = strtotime('next Monday', $year_start);
    }

    // 第几周的开始时间
    if ($week===0){
    $weekday['start'] = strtotime('last Monday', $year_start);
    }elseif ($week===1){

    $weekday['start'] = $start;
    }else{

    $weekday['start'] = strtotime('+'.($week-0).' monday',$start);
    }

    // 第几周的结束时间
    $weekday['end'] = strtotime('+1 sunday',$weekday['start']);

    if (date('m',$weekday['end'])!=$month){
    $weekday['end'] = $month_end;
    }else{
    $weekday['end'] = date("Y-m-d",$weekday['end']);
    }
    if (date('m', $weekday['start'])!=$month){
    $weekday['start'] = $month_start;
    }else{
    $weekday['start'] = date("Y-m-d",$weekday['start']);
    }

    return $weekday;
    }

     

    展开全文
  • 写sql语句分别按,星期,,季度,统计销售额 --按select sum(consume),day([date]) from consume_record where year([date]) = '2006' group by day([date])--按quarterselect sum(consume),datename...

    写sql语句分别按日,星期,月,季度,年统计销售额

    --按日 
    select sum(consume),day([date]) from consume_record where year([date]) = '2006' group by day([date]) 

    --按周quarter 
    select sum(consume),datename(week,[date]) from consume_record where year([date]) = '2006' group by datename(week,[date]) 

    --按月 
    select sum(consume),month([date]) from consume_record where year([date]) = '2006' group by month([date]) 

    --按季 
    select sum(consume),datename(quarter,[date]) from consume_record where year([date]) = '2006' group by datename(quarter,[date]) 
     

    --按年

    select sum(consume),year([date]) from consume_record where  group by year([date])

    转载于:https://www.cnblogs.com/ywcz060/p/3469346.html

    展开全文
  • Stata: 收益转周\\季\年度数据

    千次阅读 2018-12-25 10:19:24
      作者:朱红兵 (南京大学)   责编:王俊 (中山大学) ...使用 ascol 将收益率数据转换为**\\季\ 度数据; 使用 mtoq 将数据转换为季度数据;   1 两种收益率的计算 例如 我们有下述股票的度价格...

    作者:朱红兵 (南京大学)

    责编:王俊 (中山大学)

    Stata 连享会: 知乎 | 简书 | 码云 | CSDN

    连享会计量方法专题……

    本文要点

    • 解释简单收益率和对数收益率的差异;
    • 使用 ascol 将日收益率数据转换为**周\月\季\年 度数据;
    • 使用 mtoq 将月数据转换为季度数据;


    1 两种收益率的计算

    例如 我们有下述股票的日度价格序列:

    股票id 日期 价格
    1 20180101 15
    1 20180102 19
    1 20180103 17
    1 20180104 16
    1 20180105 20
    1 20180106 18
    1 20180107 19

    根据简单收益率和对数收益率计算公式:

    简单算术收益率 EQ1

    (1)SimpleReturni,t=Pricei,tPricei,t1Pricei,t1SimpleReturn_{i,t}=\frac{Price_{i,t}-Price_{i,t-1}}{Price_{i,t-1}} \tag{1}

    连续对数收益率 EQ2

    (2)SimpleReturni,t=ln(Pricei,tPricei,t1)SimpleReturn_{i,t}=ln(\frac{Price_{i,t}}{Price_{i,t-1}}) \tag{2}

    我们可以计算出简单收益率和对数收益率如下:

    股票id 日期 简单收益率 对数收益率 1+简单收益率
    1 20180102 0.2667 0.2364 1.2667
    1 20180103 -0.1053 -0.1112 0.8947
    1 20180104 -0.0588 -0.0606 0.9412
    1 20180105 0.2500 0.2231 1.2500
    1 20180106 -0.1000 -0.1054 0.9000
    1 20180107 0.0556 0.0541 1.0556

    2 区间内收益率的计算

    在实证研究中,很多时候我们希望得到周收益率或者月度收益率,那么如何根据日度收益率得到这些指标呢?

    可能很多同学会想当然地认为:直接加总日收益率即可!为题在于:直接对简单收益率进行加总得到的周(月)收益率等于对数日收益率的加总吗?我们可以用上述数据来测试看一下(计算 2018 年 1 月 2 日至 2018 年 1 月 7 日的持有期收益率):

    • 简单收益率的加总:

    0.26670.10530.0588+0.25000.1000+0.0556=0.30820.2667-0.1053-0.0588+0.2500-0.1000+0.0556=0.3082

    • 对数收益率的加总:

    0.23640.11120.0606+0.22310.1054+0.0541=0.23640.2364-0.1112-0.0606+0.2231-0.1054+0.0541=0.2364

    • 两者差异:

    0.30820.2364=0.07180.3082-0.2364=0.0718

    问题: 为什么两者会相差 0.0718 呢?哪种计算方法才能准确反应投资者在 2018 年 1 月 2 日至 2018 年 1 月 7 日 期间内的持有收益呢?


    答案对数日收益率的加总,即下式 (EQ3):

    (3)Returni,[tt0,tT]=t=t0TLogReturni,tReturn_{i,[t_{t0},t_{T}]}=\sum_{t=t0}^T{LogReturn_{i,t}} \tag{3}

    因为,区间内简单日收益率的加总意味着投资者每天都在进行交易,而非在区间内买入并持有至末期。当然,我们也可以通过简单算术日收益率计算区间内的持有期收益,但是需要采用下述方法:

    持有期收益率 (EQ4):

    (4)Returni,[tt0,tT]=Pricei,TPricei,tt0Pricei,tt0 Return_{i,[t_{t0},t_{T}]}=\frac{Price_{i,T}-Price_{i,t_{t0}}}{Price_{i,t_{t0}}} \tag{4}

    或者采用 (EQ5):

    (5)Returni,[tt0,tT]=t=t0T(1+SimpleReturni,t)1 Return_{i,[t_{t0},t_{T}]}=\prod_{t=t0}^T{(1+SimpleReturn_{i,t})}-1 \tag{5}

    3 Stata命令介绍:ascol

    3.1 安装 ascol

    在 Stata 命令框中输入下述命令并回车,即可实现安装:

    ssc install ascol, replace
    

    3.2 如何调用该命令进行收益率计算?

    ascol 的完整语法格式如下:

    ascol varname, returns([simple | log]) ///
          prices ///
          keep([all | vars]) ///
          frequency_options  ///
          timevar(varname) panelvar(varname) ///
          generate(newvar)
    

    其中:

    • varname 主要是收益率序列或者价格序列。
    • returns() 中可选择 simplelog。其中,simple 表明 varname 是简单收益率;log 代表对数收益率。若 varname 设定的是价格序列,则这里的选择会指导具体收益率序列的计算方式。
    • prices 指定了 varname 中序列的类型是否为价格序列,如果是收益率序列则无需填写。
    • keep 选项可保留计算后的重复数据,例如日收益率转换为月收益率后,在相同月会出现多个相同的收益率观测,如果选择了 keep 命令则保留了相同的观测,反之则只每个时间点上保留一个观测,剔除了重复观测
    • frequency_options 中可设定 toweektomonthtoquarter, toyear,即由日收益率转换为不同频率 (周,月,季,年) 的收益率。
    • timevar()panelvar() 选项可设定数据的时间变量和截面变量。
    • generate() 可设定新生产的收益率序列的名称。

    3.3 Stata 范例

    下述代码来源于 ascol 的官方帮助文档,读者可自行前往查看

    /*生产收益率序列*/
    clear
    set obs 1000
    gen date=date("1/1/2012" , "DMY")+_n
    format %td date
    tsset date
    gen pr=10
    replace pr=pr[_n-1]+uniform() if _n>1
    gen simpleRi=(pr/l.pr)-1
    gen logRi = ln(pr/l.pr)
    save "stocks.dta", replace
    
    /*Example 1: From Daily to weekly -  simple returns*/
    use stocks, clear
    ascol simpleRi, toweek returns(simple)
    
    /*Example 2: From Daily to weekly -  log returns*/
    use "stocks", clear
    ascol logRi, toweek returns(log)
    
    /* Example 3: From Daily to monthly -  prices*/
    use "stocks", clear
    ascol pr, tomonth price
    

    3.4 补充一个新命令 mtoq

    前文介绍的 ascol 命令虽然可以将日收益率转换为其他频率的收益率,但是有些时候我们下载的收益率月度收益率,那如何将其转换为季度收益率呢?我们写了一个新的命令 mtoq 来实现这一功能。

    Step1 安装 mtoq
    /* 1. 没有安装 github 命令的请先通过下述命令进行安装 */
    net install github, from("https://haghish.github.io/github/")  replace
    
    /* 2. 安装过 github 命令的同学可忽略上述命令,直接进行下述安装 */
    github install zhbsis/mtoq
    
    Step2 调用 mtoq

    mtoq 命令的语法非常简洁,如下:

    mtoq varlist, by(string) [Statistics(string)]
    

    其中,

    • varlist 中填写对数收益率序列,可同时填写多个序列。
    • by 选项中填写个体和时间截面的id,例如股票类数据可填写 stkcd(股票代码) ym(年月时间标记)
    • Statistics 选项中可填写 Stata 官方命令 egen 中的常见 option ,例如 mean、sum 等,默认为 mean 处理,在月度收益率转换为季度收益率的时候通常填写 sum 选项。

    Tipsmtoq 命令可以有更为广泛的用途。上面的例子是对收益率序列进行转换,但 mtoq 也可以转换其他变量,如 换手率 (TurnOver)。若想通过加总月度换收益率得到季度的换手率,可输入:

    mtoq TurnOver, by(stkcd ym) s(sum)
    


    关于我们

    • Stata 连享会(公众号:StataChina)】由中山大学连玉君老师团队创办,旨在定期与大家分享 Stata 应用的各种经验和技巧。
    • 公众号推文同步发布于 CSDN-Stata连享会简书-Stata连享会知乎-连玉君Stata专栏。可以在上述网站中搜索关键词StataStata连享会后关注我们。
    • 点击推文底部【阅读原文】可以查看推文中的链接并下载相关资料。
    • Stata连享会 精品专题 || 精彩推文

    联系我们

    • 欢迎赐稿: 欢迎将您的文章或笔记投稿至Stata连享会(公众号: StataChina),我们会保留您的署名;录用稿件达五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。您也可以从 连享会选题平台 → [002_备选主题] 中选择感兴趣的题目来撰写推文。
    • 意见和资料: 欢迎您的宝贵意见,您也可以来信索取推文中提及的程序和数据。
    • 招募英才: 欢迎加入我们的团队,一起学习 Stata。合作编辑或撰写稿件五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。
    • 联系邮件: StataChina@163.com

    往期精彩推文

    连享会计量方法专题……


    欢迎加入Stata连享会(公众号: StataChina)

    展开全文
  • time.strftime("%m", x_star_time_array) day = time.strftime("%d", x_star_time_array) month_name = str(year) + '' + str(month) + '' month_name_short = str(year) + 'M' + str(month) now_dimte = ...
  • 下面总结下使用该日历控件选择、季度、的方法。 1、选择 <input id="d1212" class="Wdate" type="text" onfocus="WdatePicker({dateFmt:'yyyy'})"/> 2、选择季度: <input id="d121....
  • 如: 表:consume_record ...请问怎么写四条sql语句分别按,按,按,按季统计消费总量. 如:1 1200元 2 3400元 3 2800元 --按 select sum(consume),day([date]) from consume_record ...
  • a选择时间在30天内,按照天的维度展示,b超出30天,按照维度展示,自然即可,展示具体的时间区间,例:第一(71~7),第二(78~14)第三(715~22)第四(723~30)第五选择三天...
  • SQL统计语句 如: 表:consume_record ...请问怎么写四条sql语句分别按,按,按,按季统计消费总量. 如:11200元 23400元 32800元 --按 selectsum(consume),day([date])fromconsum...
  • 格式 5 202006月01日 下午17:54 /// 6、其他样式:月日 + 显示上午或下午 + 收发消息的时间; 格式 6 6月01日 下午17:54 /// /// 使用: /// 例:String _time = GlobalVariable.timeUtils(startTime: "2020-09-...
  • 20171126日周赛四

    2017-11-28 18:51:59
    A  日期转换:HDU - 2133 题目描述: 今天小明想要去找小红约会,于是他中午吃过饭就跑去和妈妈说要去小红家,小明妈妈说作业写...已知,今天是2017十一25号 Saturday, 给你一个日期,说说那天是星期几? 小明
  • 这一我们训练的内容主要是写代码,做题,锻炼的是自己的思维能力和动手能力,这一感觉感觉没有学很多。无论是做题还是看书,都感觉效率超级低,一道题有时候都能卡一上午。写代码半个小时,debug改一天。太难了...
  • 1.认识.NET平台,了解C#和VS软件的入门基础知识; 2.学习编程中的注释符和C#中的快捷键; 3学习变量(变量的存储、类型、使用规则等); 4.学习运算符,进行两个练习; 5.学习类型转换和if结构; ...
  • select cast(datediff(mm,csdate+ '-01',getdate())/12 as varchar)+'' +cast(case when datepart(dd,getdate())>=datepart(dd,csdate+ '-01') then datediff(mm,csdate+ '-01',getdate())%12 else datediff(mm...
  • 其实这里用到的及时将时间进行to_char转换以后进行分组的过程,下面举个例子进行说明: 比如一个表中有一个字段为 stat_time为date型,要基于她进行各种分类统计。   1. 按 select count(1),sum(1),to_...2.按
  • CV君汇总了过去一计算机视觉领域新出的开源代码,涉及到图像质量评价、图像去雾、图像修复、医学图像分割、目标检测、人脸对齐、度量学习等,其中有多篇来自CVPR 2019的论文代码。 希望对你有帮助~ 非参图像质量...
  • 第六 数制转换

    2015-10-12 17:04:18
    /* *Copyright (c++)2015,烟台大学... *All rights reserved.... *文件名称:第6项目-数制转换.cpp *作 者:纪冬雪 ...*完成日期:20151011 *版 本 号:v1.0 *问题描述:把十进制的整数转换为二至九之间
  • 程序员一国际要闻:Visual Studio 2010 和.NET 4.0 Beta 1 发布自:http://news.csdn.net/a/20090527/211544.html 导读:本文翻译自著名程序员Justin James的博客。他在文中整理了在刚过去的一里开发者应该...
  • 十二进制转换

    2016-11-29 16:48:45
    完成时间:20161117 题目描述 输入一个十进制数N,将它转换成R进制数输出。 输入 输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(210)。 输出 为每个测试实例输出转换后的数,每个...
  • 我突然意识到,最近三,都大部分停留在想和不敢做的状态,大部分时间都被荒废了。 而真正要走的路,还有要完成的目标,一个都还没有完成。包括选择一条职业之路并转行,包括完善自己的学历。 我突然想明白了,前几...
  • 第六项目 数制转换

    2015-10-23 08:18:28
    /* Copyright (c)2015,烟台... All rights reserved.... 文件名称:第6项目4--数制转换.cpp 作 者:孙钦达 ...完成日期:20151017 版 本 号:v1.0 问题描述:把十进制的整数转换为二至九之间的任一进制数
  • 大众计划在2020前投资8.7亿欧元(约合合9.8545亿美元)开发电动汽车零部件。新开设的电池部门将负责电池和电池组的制造,并监督旧电池的回收。大众品牌目前有两款全电动汽车。到2025,这一数字将增至20...
  • 一、时间格式化处理:----Wed Apr 10 2019 17:48:09 GMT+0800 (中国标准时间) ... 2、字符串时间格式:var end_date = new Date(informationTime.replace(/-/g, "/")) // replace(/-/g, "/") 用于格式化日期...
  • 要点探讨 Stringdate &lt;if test="date eq 'Mon' "... AND DATE_FORMAT( STR_TO_...%Y%m%d %H时%i分%s秒"), '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' ) &lt;/if&g...
  • /* Copyright (c)2015,烟台大学计算机与控制... All rights reserved.... 文件名称:第6项目4--数制转换.cpp 作 者:吕云双 ...完成日期:20151012 版 本 号:v1.0 问题描述:十进制 */#define Max
  • 第12 oj 进制转换

    2016-11-18 16:32:53
    完成日期:20161118 题目描述 输入一个十进制数N,将它转换成R进制数输出。 输入 输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(210)。 输出 为每个测试实例输出转换后的数,每个...
  • 问题及代码: main.cpp: /* Copyright (c)2016,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:数制转换.cpp 作 者: 国亮 完成日期:2016926 版 本 号:v1.0
  • 第五项目4数制转换

    2016-09-30 10:01:58
    完成日期:2016930 版 本 号:v1.0 问题描述:把十进制的整数转换为二至九之间的任一进制数输出。请利用栈设计算法,并实现程序。 输入描述:数字与进制 程序输出:输出转换结果 */ 代码: #

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 838
精华内容 335
关键字:

月日年转周