gpt4 book ai didi

date - 如何在 Stata 中创建日期序列?

转载 作者:行者123 更新时间:2023-12-05 09:22:21 29 4
gpt4 key购买 nike

我想在 Stata 中创建一个日期序列。在此论坛和其他论坛上的搜索没有为 Stata 提供任何有用的代码。 R 有很多答案,例如 this。关联。我想创建一个从 2000 年 1 月 1 日到 2010 年 12 月 31 日的序列。我该怎么做?

最佳答案

日期在任何软件中都可能很棘手。在 Stata 中,与任何其他软件一样,仔细阅读文档确实是无可替代的。 help dates and times 回答了大多数问题。 Stata 中的 date() 是一个用于创建daily 日期变量的函数,而不是其他类型。从 Stata 13 开始,新用户在查找每日日期时最好使用同义函数 daily()。也就是说,另一个函数在这里更方便地创建日期序列,mdy()

这是一个例子:

clear 
di mdy(1,1,2000)
di mdy(12,31,2010)
di mdy(12,31,2010) - mdy(1,1,2000)
set obs 4018
gen mydate = mdy(12,31,1999) + _n
format mydate %td
list in 1
list in L

注意事项:

  1. mdy() 根据指示月、日和年的参数创建每日日期变量。

  2. _n 是观测数,1 up。

  3. 因此您需要计算出开始日期和所需的观察次数,然后只需将所需常量添加到 _n 即可。

  4. Stata 使用每日日期起源于 1960 年 1 月 1 日,但此解决方案并不取决于您是否知道这一点。

附言在现已删除的答案中,@Caty 似乎要求提供一系列每月日期。这是一个编辑过的版本:

When I try that, my dates look like this 01jan2000, 02jan2000. But they should be monthly: 01jan2000, 01feb2000.

如果您有月度数据,那么使用每月第一天的每日日期完全没有必要,也没有任何优势,至少就 Stata 而言是这样。事实上,通过创建这样的序列,您创建了一个间隔为 27、28、29 和 30 天的序列,因此甚至不是规则间隔的序列。这些差距将使 Stata 中的许多分析变得笨拙,有些甚至无法进行。类似的评论适用于宿舍。 (如果你有周,每天相隔 7 天的日期是最好的框架,这是另一回事。)

clear 
di ym(2000, 1)
di ym(2010, 12)
di ym(2010, 1) - ym(2000,1)
set obs 121
gen mydate = ym(1999, 12) + _n
format mydate %tm
l in 1
l in L

注意事项:

  1. ym() 根据指示年份和月份的参数创建月度日期变量。

  2. _n 是观测数,1 up。

  3. 因此您需要计算出开始日期和所需的观察次数,然后只需将所需常量添加到 _n 即可。

  4. Stata 使用每月日期原点 1960 年 1 月,但此解决方案并不取决于您是否知道这一点。

EDIT 月末每日序列很简单,您可能会因为没有立即看到而自责。假设我们想要从 2015 年 1 月到 2016 年 12 月的月底。那么每个月的月底恰好是下个月月初的前一天。无需担心不同长度的月份或闰年。 Stata 知道日历的详细信息,因此您不必告诉它它们是什么。

. clear

. set obs 24
number of observations (_N) was 0, now 24

. gen mdate = ym(2015, 1) + _n

. gen ddate = dofm(mdate) - 1

. format %td ddate

. format %tm mdate

. list

+---------------------+
| mdate ddate |
|---------------------|
1. | 2015m2 31jan2015 |
2. | 2015m3 28feb2015 |
3. | 2015m4 31mar2015 |
4. | 2015m5 30apr2015 |
5. | 2015m6 31may2015 |
|---------------------|
6. | 2015m7 30jun2015 |
7. | 2015m8 31jul2015 |
8. | 2015m9 31aug2015 |
9. | 2015m10 30sep2015 |
10. | 2015m11 31oct2015 |
|---------------------|
11. | 2015m12 30nov2015 |
12. | 2016m1 31dec2015 |
13. | 2016m2 31jan2016 |
14. | 2016m3 29feb2016 |
15. | 2016m4 31mar2016 |
|---------------------|
16. | 2016m5 30apr2016 |
17. | 2016m6 31may2016 |
18. | 2016m7 30jun2016 |
19. | 2016m8 31jul2016 |
20. | 2016m9 31aug2016 |
|---------------------|
21. | 2016m10 30sep2016 |
22. | 2016m11 31oct2016 |
23. | 2016m12 30nov2016 |
24. | 2017m1 31dec2016 |
+---------------------+

关于date - 如何在 Stata 中创建日期序列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27501383/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com