Bookmark and Share

Notice: On April 23, 2014, Statalist moved from an email list to a forum, based at statalist.org.


[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

st: Merging annual data and monthly data few months after year end


From   "Abdalla, Ahmed" <[email protected]>
To   "[email protected]" <[email protected]>
Subject   st: Merging annual data and monthly data few months after year end
Date   Fri, 17 Jan 2014 18:35:18 +0000

Dear Statalist
I have two databases:
a) ccm.dta that includes "annual" accounting data at fiscal year end for a set of firms over 20 years (however, unbalanced). 

Permno (firm identifier)   datadate                          yr             mth               x1          x2

10001                                    30june1988                  1988            6                 
10001                                    30june1989                  1989            6
10001                                    31december1990        1990            12
10002                                    30april1988                  1988             4
10002                                    30april1989                  1989             4           
10002                                    31may                           1990            5

Note that a company may change its fiscal year end. A company that reports accounting data at the end of June this year may report data at December in the next year (or sometimes at the same year).

b) crsp.dta that includes "monthly"stock prices for the same set of firms over the same period (however, unbalanced)

Permno (firm identifier)      datadate                                  yr       mth     x3(stockprice)
10001                                    29january1988                      1988       1
10001                                    29february1988                    1988       2
10001                                    31march1988                        1988       3
10001                                    29april1988                           1988       4
10001                                    31may1988                            1988       5
10001                                    30june1988                           1988       6
10001                                    31july1988                             1988      7
....                                           ....
....                                           ...31dec1988                         1988      12

10001                                    29january1989                      1989     1
10001                                    29february1989                     1989     2
10001                                    31march1989                        1989      3
10001                                    29april1989                           1989     4
10001                                    31may1989                            1989     5
10001                                    30june1989                            1989    6
10001                                    31july1989                             1989     7
....                                           ....
....                                           ...31dec1989                          1989    8

10002                                    29january1988                       1988    1                 
10002                                    29february1988                     1988     2
10002                                   31march1988                          1988     3
10002                                    29april1988                            1988     4
10002                                    31may1988                             1988    5
10002                                    30june1988                             1988    6
10002                                    31july1988                               1988   7
....                                           ....
....                                           ...31dec1989                            1988 12


I want to merge both data sets and link annual accounting data in ccm.dta to stock prices reported at the end of fiscal year and three months after the end of the fiscal year. Here is the code I used:

use ccm.dta
duplicates drop
format datadate %d
  * yr and mth were not reported in the original data in both datasets, however I wrote them in my example above*
gen yr=year(datadate) 
gen mth=month(datadate)
drop if permno==.
sort permno yr mth
save ccm_2.dta

use crsp.dta,clear
duplicates drop
format date %d
gen yr=year(date)
gen mth=month(date)
drop if permno==.
sort permno yr mth
merge 1:1 permno yr mth using ccm_2.dta
egen firmid= group(permno)
egen timeid=group(yr mth)
tsset firmid timeid
gen prc3=f3.prc
keep if _merge==3


The code didn't work and gives error messages that I couldn't fix and especially when I "tsset" my panel.

Would you please suggest a proper code to merge these two datasets and link x1 x2 (annual data) to x3 (stock prices) at fiscal year end and three months after fiscal year end ?

Many thanks in advance
Ahmed





  
 
 
 
     
*
*   For searches and help try:
*   http://www.stata.com/help.cgi?search
*   http://www.stata.com/support/faqs/resources/statalist-faq/
*   http://www.ats.ucla.edu/stat/stata/


© Copyright 1996–2018 StataCorp LLC   |   Terms of use   |   Privacy   |   Contact us   |   Site index