*! version 1.0.4 05nov2009 logout by roywada@hotmail.com *! Converts log or ASCII files into various output formats program define logout local _original `0' versionSet version `version' /* "using" no longer used * encase the colon in file name in quotes, avoiding string function length limits local behind `"`0'"' local 0 "" gettoken front behind: behind, parse(" ,") local 0 "" local done 0 while `"`front'"'~="" & `done'==0 { if `"`front'"'=="using" { gettoken rest behind: behind, parse(" ,") * strip off quotes gettoken first second: rest, parse(" ") cap local rest: list clean local(rest) * take off colon at the end local goldfish "" if index(`"`rest'"',":")~=0 { local end=substr(`"`rest'"',length(`"`rest'"'),length(`"`rest'"')) if "`end'"==":" { local rest=substr(`"`rest'"',1,`=length(`"`rest'"')-1') local goldfish " : " } } * colon reattached with a space at the end * .txt attached here for seeout working with _pref.ado local rabbit `"""' if index(`"`rest'"', ".")==0 { local using `"`rabbit'`rest'.txt`rabbit'`goldfish'"' } else { local using `"`rabbit'`rest'`rabbit'`goldfish'"' } local 0 `"`0' using `using' `behind'"' local done 1 } else { local 0 `"`0' `front'"' gettoken front behind: behind, parse(" ,") } } */ gettoken first second : 0, parse(":") `bind' match(par) quotes local 0 `"`first'"' while `"`first'"'~=":" & `"`first'"'~="" { gettoken first second : second, parse(":") `bind' match(par) quotes } if `"`0'"'==":" { * colon only when shorthand combined with prefix local 0 } else { * not used local _0 `"`0'"' } *** shorthand syntax if use file is missing syntax[, use(string) save(string) FIX1(numlist) clear FIX fixcut(numlist) text smcl* range(string asis)] if "`fixcut'"~="" { local fix fix } if "`clear'"~="clear" { preserve } if "`fix1'"~="" { local fix "fix" } if "`Version7'"=="" & "`fix'"=="" { * must be fix local fix fix noi di in yellow "fix option inserted" } * regular stuff if `"`use'"'~="" { * with use file * `second' could contain " " only ??? gettoken a b : second, parse(" ") if `"`a'"'~="" { noi di in red "cannot combine {opt use( )} with command statements at end; use one or the other" exit 198 } if "`fix1'"=="" { local fix1 5 } *`second' if `"`range'"'~="" { tempfile capfile2 gettoken one two: range, parse("/") gettoken splash two: two, parse("/") _chewfile using `"`use'"', save(`capfile2') replace begin(`one') end(`two') _logout, use(`"`capfile2'"') save(`"`save'"') `options' fix1(`fix1') `clear' `fix' fixcut(`fixcut') original(`_original') range(`range') } else { _logout, use(`"`use'"') save(`"`save'"') `options' fix1(`fix1') `clear' `fix' fixcut(`fixcut') original(`_original') range(`range') } } else { * with temporary file tempfile capfile local tempfile tempfile if "`Version7'"=="" { * a permanent file name for version 7 local capfile "logout.txt" } * `second' could contain " " only gettoken a b : second, parse(" ") if `"`a'"'~="" { cap unabcmd `a' if _rc==0 { * it's a command if (`"`r(cmd)'"'=="table" | `"`r(cmd)'"'=="tabstat") & "`fix1'"=="" { local fix1 1 } } if "`fix1'"=="" { local fix1 5 } noi caplog using `"`capfile'"', tempfile replace `text' `smcl' subspace: `second' if `"`range'"'~="" { tempfile capfile2 gettoken one two: range, parse("/") gettoken splash two: two, parse("/") _chewfile using `"`capfile'"', save(`capfile2') replace begin(`one') end(`two') _logout, use(`"`capfile2'"') save(`"`save'"') `options' fix1(`fix1') tempfile `clear' `fix' fixcut(`fixcut') original(`_original') range(`range') } else { _logout, use(`"`capfile'"') save(`"`save'"') `options' fix1(`fix1') tempfile `clear' `fix' fixcut(`fixcut') original(`_original') range(`range') } } else { if "`fix1'"=="" { local fix1 5 } * range needs to be activated here for dataout functionality _logout, save(`"`save'"') `options' fix1(`fix1') `clear' `fix' fixcut(`fixcut') original(`_original') range(`range') } } end ******************************************************************************************** program define _logout versionSet version `version' *syntax [using/] , [save(string) nounwrap excel word tex col row ignore(string) drop(string) clear dta ] syntax, [ save(string) use(string) nounwrap NOWIPE excel dta tex word clear /* */ NOAUTO raw right FIX FIX1(numlist >=-100 <=100 max=1) replace tempfile /* */ auto(integer 3) dec(numlist int >=0 <=11) fixcut(numlist) range(str asis)] original(str asis) * note: options original and range are not really used here: qui { local colsizeMax 1 if `"`save'"'~="" { * assign save name local beg_dot = index(`"`save'"',".") if `beg_dot'~=0 { local strippedname = substr(`"`save'"',1,`=`beg_dot'-1') local save `"`strippedname'.txt"' } else { * `save' has no extension local strippedname `"`save'"' local save `"`save'.txt"' } cap confirm file `"`save'"' if !_rc & "`replace'"~="replace" { * it exists noi di in red `"`save' exists; specify {opt replace}"' exit 198 } } else { tempfile tempsave local save `"`tempsave'"' } if "`use'"~="" { if "`tempfile'"~="tempfile" { local beg_dot = index(`"`use'"',".") if `beg_dot'~=0 { local strippedname1 = substr(`"`use'"',1,`=`beg_dot'-1') * no need to reassign name *local use `"`strippedname1'.txt"' } else { * `use' has no extension local strippedname1 `"`use'"' local use `"`use'.txt"' } } if "`drop'"~="" { if "`unwrap'"=="nounwrap" { noi di in red "Cannot combine {opt nounwrap} and {opt drop( )}" exit 198 } else { local unwrap "unwrap" } } clear cap file close _all *local 0 `"using `0'"' tempname source saving if "`unwrap'"~="nounwrap" { *** wrapping text problem ONLY local linenum = 0 file open `source' using `"`use'"', read file open `saving' using `"`save'"', write text replace file read `source' line * first line if r(eof)==0 { local linenum = `linenum' + 1 local last_macvalline `"`macval(line)'"' file read `source' line } * subsequent lines local _n while r(eof)==0 { local linenum = `linenum' + 1 cap tokenize `"`macval(last_macvalline)'"', parse(" []:") * handle the grave accent thing if _rc~=0 { noi di in yel `"line `linenum' contains a grave accent (or something), attempt was made to convert it into "grave_accent""' local last_macvalline : subinstr local last_macvalline "`" "grave_accent", all gettoken 1 2 : last_macvalline, parse(" []:") } if `"`1'"'==">" { * remove the first instance of ">" local last_macvalline : subinstr local last_macvalline "> " "" file write `saving' `"`macval(last_macvalline)'"' } else { file write `saving' `_n' cap file write `saving' `"`macval(last_macvalline)'"' if _rc~=0 { noi di in yel `"line `linenum' was unable to be written, left blank"' file write `saving' "" } } local _n "_n" local last_macvalline `"`macval(line)'"' file read `source' line } * the last line local linenum = `linenum' + 1 cap tokenize `"`macval(last_macvalline)'"', parse(" []:") * handle the grave accent thing if _rc~=0 { noi di in yel `"line `linenum' contains a grave accent (or something), attempt was made to convert it into "grave_accent""' local last_macvalline : subinstr local last_macvalline "`" "grave_accent", all gettoken 1 2 : last_macvalline, parse(" []:") } if `"`1'"'==">" { * remove the first instance of ">" local last_macvalline : subinstr local last_macvalline ">" "" file write `saving' `"`macval(last_macvalline)'"' } else { file write `saving' `_n' cap file write `saving' `"`macval(last_macvalline)'"' if _rc~=0 { noi di in yel `"line `linenum' was unable to be written, left blank"' file write `saving' "" } } local _n "_n" * close out with the last line file write `saving' _n file close `source' file close `saving' } if "`unwrap'"~="nounwrap" { file open `source' using `"`save'"', read } else { file open `source' using `"`use'"', read } if "`fix'"=="fix" { *** fix files _logfix, use(`use') fix1(`fix1') fixcut(`fixcut') } else { *** delimited files local col_size 98 local linenum = 1 file read `source' line local OBS 50 set obs `OBS' if "`raw'"=="raw" { gen str7 raw="" replace raw=`"`line'"' in 1 local _format= "`: format raw'" local _widths=substr("`_format'",2,length(trim("`_format'"))-2) format raw %-`_widths's } gen rowLine=. gen tokenMax=. * this adjusted forval num=1/`colsizeMax' { gen str2 t`num'="" } while r(eof)==0 { if `linenum'>`OBS'-1 { local OBS=`OBS'+50 cap set obs `OBS' if _rc==198 { noi di in red "Cannot increase observation number beyond `OBS': probably need more memory" } } *display %4.0f `linenum' _asis `" `macval(line)'"' local checking=substr(trim(`"`macval(line)'"'),1,5) *noi di `"`checking'"' if `"`checking'"'=="-----" { replace rowLine=`linenum' in `linenum' replace t1=`"`checking'"' in `linenum' } else { local macvalline `"`macval(line)'"' local macvalline : subinstr local macvalline "Prob > chi2" "Prob>chi2", all local macvalline : subinstr local macvalline "Number of groups" "Number_of_groups", all local macvalline : subinstr local macvalline "Obs per group: min" "Obs_per_group_min", all local macvalline : subinstr local macvalline "Number of obs" "Number_of_obs", all local macvalline : subinstr local macvalline "Root MSE" "Root_MSE", all local macvalline : subinstr local macvalline "Prob > F" "Prob>F", all local macvalline : subinstr local macvalline "Std. Err." "Std.Err.", all local macvalline : subinstr local macvalline "Std. Dev." "Std.Dev.", all local macvalline : subinstr local macvalline "95% Conf." "95%_Conf.", all local macvalline : subinstr local macvalline "Sum of Wgt." "Sum_of_Wgt.", all local macvalline : subinstr local macvalline "log pseudolikelihood" "log_pseudolikelihood", all cap tokenize `"`macvalline'"', parse(" []:`=char(9)'") * handle the grave accent thing if _rc~=0 { noi di in yel `"line `linenum' contains a grave accent (or something), attempt was made to convert it into "grave_accent""' local macvalline : subinstr local macvalline "`" "grave_accent", all tokenize `"`macvalline'"', parse(" []:`=char(9)'") } * numToken is the token number * numCol is the column number local numToken=1 local numCol=1 local stop "" replace rowLine=`linenum' in `linenum' while `"``numToken''"'~="" & "`stop'"~="stop" { if `"``numToken''"'~="[" & /* */ `"``numToken''"'~="]" & /* */ `"``numToken''"'~=":" & /* */ `"``numToken''"'~="|" & /* */ `"``numToken''"'~="`=char(9)'" { * add more columns if necessary if `numToken'>=`colsizeMax' { local colsizeMax=`colsizeMax'+1 gen str2 t`colsizeMax'="" if "`c(flavor)'"=="small" & `colsizeMax'>=`col_size' { noi di in yel `"Stata flavor "small", unable to have more than 99 columns"' local stop stop } } *noi di in red `"``numToken''"' _c *noi di in green "" replace t`numCol'=`"``numToken''"' in `linenum' /* * auto-digits local check = `"``numToken''"' capture confirm number `check' *noi di in green "`=_rc'" if _rc==0 & "`noauto'"~="noauto" { * only if a number autodigits2 `"``numToken''"' `auto' local valstr = string(`check',"%12.`r(valstr)'") *noi di in yel `"`valstr'"' /* prevent adding non-signnificant 0 at the end ****** does NOT handle scientific notations, or does it? local beg_dot1 = index(`"``numToken''"',".") local stripped1 = substr(`"``numToken''"',`=`beg_dot1'+1',.) local length1 : length local stripped1 local beg_dot2 = index(`"`valstr'"',".") local stripped2 = substr(`"`valstr'"',`=`beg_dot2'+1',.) local length2 : length local stripped2 if `length2'<=`length1' & `length2'~=0 & `beg_dot2'~=0 & `length1'>0 { replace t`numCol'=`"`valstr'"' in `linenum' } else { replace t`numCol'=`"``numToken''"' in `linenum' } */ replace t`numCol'=`"`valstr'"' in `linenum' } else { * only if not a number replace t`numCol'=`"``numToken''"' in `linenum' } */ replace tokenMax=`numCol' in `linenum' local numCol=`numCol'+1 } local numToken=`numToken'+1 } } file read `source' line * noi di `"`macval(line)' dd `r(eof)'"' local linenum = `linenum' + 1 if "`raw'"=="raw" { replace raw=`"`macval(line)'"' in `linenum' } } /* works with pre-tokenized columns, but not used because tokenize better if already unwrapped as above, * mostly due to the handling of rabbit-ears poking out * wrapping text problem if "`unwrap'"~="nounwrap" { * skip first line forval num=`=_N'(-1)2 { if token1==">" in `num' { * counter keeps track of which column being moved to the right end of the previous row * token1 is skipped since it has < forval counter=2/`=tokenMax[`num']' { replace t`=tokenMax[`num'-1]+`=`counter'-1''=t`counter'[`num'] in `=`num'-1' } replace tokenMax=tokenMax[`num'-1]+tokenMax[`num'] in `=`num'-1' } } } */ /* this is slow local num `colsizeMax' local stop "" while `num' > 1 & "`stop'"=="" { count if t`num'=="" if r(N)==_N { drop t`num' } else { local stop "stop" } local num=`num'-1 } */ * clean up if "`row'"~="row" { drop rowLine } if "`col'"~="col" { drop tokenMax } * drop extra columns indiscriminately * this is slow foreach var of varlist _all { count if `var'=="" if r(N)==_N { drop `var' } } * drop from top gen rowmiss=0 foreach var of varlist _all { * cap because rowmiss is non-string cap replace rowmiss=rowmiss+1 if `var'~="" & "`var'"~="rowmiss" } local N=_N local oldN while "`N'"~="`oldN'" { local oldN=_N drop in 1 if rowmiss==0 local N=_N } * drop from bottom local N=_N local oldN while "`N'"~="`oldN'" { local oldN=_N drop in `oldN' if rowmiss==0 local N=_N } drop rowmiss file close `source' file close _all } /*** delimited files */ } /* if "`using'"~="" */ if "`nowipe'"~="nowipe" & "`fix'"~="fix" { cap drop if t1=="-----" | t1=="opened" | t1=="log" | t1=="." | t1=="closed" } /* workaround to see if heading should be reported local noheading 0 local test 0 foreach var of varlist local temp=instr("`var'",1,2) capture confirm string `temp' if _rc==0 { local * only if a string local test 1 } } local temp=instr("`var'",2,3) capture confirm number `temp' if _rc==0 & "`test'"=="1" { * only if a number local noheading=`noheading'+1 } } } */ * replace the gap holders for value labels * heading for _dataout if "`use'"~="" | "`clear'"=="clear" { * not being used as dataout local head "head" foreach var of varlist _all { replace `var'= subinstr(`var',"_"," ",.) local heading "nohead" } else { *local heading "head" * make it always nohead local heading "nohead" } } local heading "nohead" } /* quietly */ * display the fix command if "`fixcutCollect'"~="" { *di in yel `" logcut`original' fixcut(`fixcutCollect')"' gettoken one two: fixcutCollect, parse(" ") di in yel `" fixcut(`one'`two')"' } * display unless temp file was used or not given at all (used the current file in memory) if "`tempfile'"~="tempfile" & `"`usingTerm'"'~="" { local usingTerm `"`use'"' local cl_text `"{browse `"`usingTerm'"'}"' noi di as txt `"`cl_text'"' } * export files local doit local doit "`doit'`excel'" local doit "`doit'`word'" local doit "`doit'`tex'" local doit "`doit'`dta'" if `"`doit'"'~="" { di * add one row if 2 or less local N=_N if `N'<3 { qui { tempvar order if `N'==0 { set obs 3 } else { * `N'==1 | `N'==2 gen `order'=_n set obs 3 local N=_N replace `order'=0 in `N' sort `order' drop `order' } } } if "`dec'"~="" { local noauto "noauto" } if "`save'"=="" { noi di in red "must specify {opt save( )}" exit 198 } * workaround for names ds8 local names `"`r(varlist)'"' local strippednameUse `"`strippedname'"' if `"`strippedname'"'=="" { local strippednameUse `"`strippedname1'"' } _dataout, save(`"`strippednameUse'"') `excel' `tex' `word' `dta' `replace' `heading' `noauto' auto(`auto') dec(`dec') * folder _cdout local num 1 foreach var of varlist _all { local temp: word `num' of `names' ren `var' `temp' local num=`num'+1 } } /* file open `saving' using `save', write text replace forval linenum=1/`=_N' { local content=raw[`linenum'] file write `saving' `"`macval(content)'"' _n local linenum = `linenum' + 1 } file close _all */ end ******************************************************************************************** program define _logfix versionSet version `version' qui { syntax, use(string) FIX1(numlist) [fixcut(numlist)] *** determine the widths of file local infix forval num=1/45 { local infix "`infix' str1 t`num' `num'-`num'" } infix `infix' using `"`use'"', clear local col_size 45 * checking the end of file: count if t41~="" local rN41 `r(N)' count if t42~="" local rN42 `r(N)' count if t43~="" local rN43 `r(N)' count if t44~="" local rN44 `r(N)' count if t45~="" local rN45 `r(N)' local count=`rN41'+`rN42'+`rN43'+`rN44'+`rN45' if `count'~=0 { * do over local infix forval num=1/495 { local infix "`infix' str1 t`num' `num'-`num'" } infix `infix' using `"`use'"', clear local col_size 495 } *drop if t1=="-" & t2=="-" & t3=="-" & t4=="-" & t5=="-" _infix, use(`use') fix1(`fix1') col_size(`col_size') fixcut(`fixcut') /* example gen indicate=1 if rowmiss==0 replace indicate=sum(indicate) *logout, save(mystuff1) excel fix(10) replace noauto: reg price mpg rep78 head *logout, save(mystuff2) excel nowipe replace noauto: reg price mpg rep78 head _infix in 8/`=_N', use(`use') fix1(10) col_size(`col_size') fixcut(`fixcut') gen wave=2 save fixing, replace _infix in 1/7, use(`use') fix1(19) col_size(`col_size') fixcut(`fixcut') append using fixing replace wave=1 if wave==. aorder t* browse logleft, wave_top(1) wave_bot(2) browse */ cap drop rowmiss cap drop indicate } * return c_local fixcutCollect `"`fixcutCollect'"' end /* logfix */ ******************************************************************************************** program define logleft syntax, wave_top(numlist) wave_bot(numlist) unab varList: t* tokenize `varList' local varCount: word count varList local var1 1 local var2 2 while "``var2''"~="" { count if ``var1''~="" & wave==`wave_top' local rN1_top=r(N) count if ``var1''~="" & wave==`wave_bot' local rN1_bot=r(N) count if ``var2''~="" & wave==`wave_top' local rN2_top=r(N) count if ``var2''~="" & wave==`wave_bot' local rN2_bot=r(N) if `rN1_top'~=0 & `rN1_bot'==0 & `rN2_top'==0 & `rN2_bot'~=0 { replace ``var1''=``var2'' if wave==`wave_bot' drop ``var2'' local var1=`var1'+1 local var2=`var2'+1 } else if `rN1_top'==0 & `rN1_bot'~=0 & `rN2_top'~=0 & `rN2_bot'==0 { replace ``var1''=``var2'' if wave==`wave_top' drop ``var2'' local var1=`var1'+1 local var2=`var2'+1 } else if `rN1_top'==0 & `rN1_bot'==0 { drop ``var1'' } local var1=`var1'+1 local var2=`var2'+1 } end ******************************************************************************************** program define _infix versionSet version `version' qui { syntax [in], use(string) FIX1(numlist) col_size(numlist) [fixcut(numlist)] local infix forval num=1/`col_size' { local infix "`infix' str1 t`num' `num'-`num'" } infix `infix' `in' using `"`use'"', clear * must be beyond square local N=_N if `N'<`col_size' { local new_size=`col_size'+5 set obs `new_size' } * replace the lines ds8 tokenize `dsVarlist' local num 0 local one=1+`num' local two=2+`num' local three=3+`num' * 165, 127, 216 while "``three''"~="" { replace ``one''="��" if ``one''=="-" & ``two''=="-" & ``three''=="-" replace ``two''="��" if ``one''=="��" & ``two''=="-" & ``three''=="-" replace ``three''="��" if ``one''=="��" & ``two''=="��" & ``three''=="-" replace ``three''="��" if ``one''=="��" & ``two''=="��" & ``three''=="+" local num=`num'+1 local one=1+`num' local two=2+`num' local three=3+`num' } ds8 local thisMany: word count `dsVarlist' gen height=. forval num=1/`col_size' { qui count if t`num'~="" & t`num'~="��" di "`r(N)' " _c replace height=`r(N)' in `num' } /* gen id=_n if _n<=100 line height id sort height drop id gen id=_n if _n<=100 line height id */ sum height, det forval wave=1/50 { * limit local times=`fix1'/1000*`wave' local parameter=`r(max)'*`times' gen trend`wave'=. replace trend`wave'=-1 if (height<height[_n-1]-`parameter' & height[_n-1]~=.) gen minima`wave'=. *replace minima`wave'=1 if trend`wave'==-1 & height<`parameter' replace minima`wave'=1 if trend`wave'==-1 * replace if still dropping in height forval num=1/10 { replace minima`wave'=0 if minima`wave'==1 & height>=height[_n+1]==1 replace minima`wave'=1 if minima`wave'[_n-1]==0 & minima`wave'==. } } egen minima=rsum(minima*) order minima* *tab minima /* local infix local begin 1 forval num=1/`thisMany' { local content=minima[`num'] if `content'>25 { local width=`num'-`begin'+1 local infix "`infix' str`width' t`num' `begin'-`num'" local begin=`num'+1 } } * noi di "`infix'" infix `infix' `in' using `"`use'"', clear */ local infix local fixcutCollect local begin 1 * automatically infix forval num=1/`thisMany' { local content=minima[`num'] if `content'>25 { local width=`num'-`begin'+1 local infix "`infix' str`width' t`num' `begin'-`num'" local fixcutCollect "`fixcutCollect' `num'" local begin=`num'+1 } } *noi di in red "`infix'" *noi di in red "`fixcutCollect'" infix `infix' `in' using `"`use'"', clear if "`fixcut'"~="" { local infix local fixcutCollect local begin 1 * manually infix local num 1 tokenize `fixcut' while "``num''"~="" { local width=``num''-`begin'+1 local infix "`infix' str`width' t``num'' `begin'-``num''" local fixcutCollect "`fixcutCollect' ``num''" local begin=``num''+1 local num=`num'+1 } *noi di in red "`infix'" *noi di in red "`fixcutCollect'" infix `infix' `in' using `"`use'"', clear local fixcut fixcutCollect } * drop verticals first local N=_N foreach var of varlist _all { count if `var'=="|" if `r(N)'>.5*`N' { drop `var' } } * stronger codes for manual infix as well * replace the horizontal lines tempvar length test cap gen `length'=. cap gen `test'=. foreach var of varlist _all { cap replace `length'=length(`var') cap replace `test'=(`length'-length(subinstr(`var',"-","",.)))/`length' if `length'>2 cap replace `var'="" if `test'>=0.5 } drop `length' `test' /* older * replace the horizontal lines tempvar length test cap gen `length'=. cap gen str7 `test'="" foreach var of varlist _all { cap replace `length'=length(`var') cap replace `test'=subinstr(`var',"-","",.) if `length'>2 cap replace `var'="" if `test'=="" } drop `length' `test' */ /* oldest replace the horizontal lines foreach var of varlist _all { local N=_N forval num=1/`N' { local content=`var'[`num'] local length=length(`"`content'"') if `length'>2 { local test : subinstr local content "-" "", all if "`test'"=="" { replace `var'="" in `num' } } } } */ compress } /* quietly */ ************ needs to cut at left if not rising anymore * drop extra columns indiscriminately * this is slow foreach var of varlist _all { count if `var'=="" if r(N)==_N { drop `var' } } * drop from top gen rowmiss=0 foreach var of varlist _all { * cap because rowmiss is non-string cap replace rowmiss=rowmiss+1 if `var'~="" & "`var'"~="rowmiss" } local N=_N local oldN while "`N'"~="`oldN'" { local oldN=_N drop in 1 if rowmiss==0 local N=_N } * drop from bottom local N=_N local oldN while "`N'"~="`oldN'" { local oldN=_N drop in `oldN' if rowmiss==0 local N=_N } * return c_local fixcutCollect `"`fixcutCollect'"' end /* _infix */ ******************************************************************************************** *** ripped from dataout Apr 2008 program define _dataout syntax [using/], [save(string) excel tex word dta NOHEAD HEAD replace NOAUTO auto(integer 3) dec(numlist int >=0 <=11)] version 7 if "`fix1'"~="" { local fix "fix" } if `"`using'"'=="" & "`save'"=="" { noi di in red "must specify {opt using} or {opt save( )}" exit 198 } if "`using'"~="" { * attach .txt if nothing attached local beg_dot = index(`"`using'"',".") if `beg_dot'==0 { local using `"`using'.txt"' } } if "`save'"=="" { * assign save name local beg_dot = index(`"`using'"',".") local strippedname = substr(`"`using'"',1,`=`beg_dot'-1') local save "`strippedname'_logout.txt" } else { * assign save name local beg_dot = index(`"`save'"',".") if `beg_dot'~=0 { local strippedname = substr(`"`save'"',1,`=`beg_dot'-1') local save `"`strippedname'.txt"' } else { * `save' has no extension local strippedname `"`save'"' local save `"`save'.txt"' } if `"`using'"'=="" { * if using file was not specified but save was: local beg_dot = index(`"`save'"',".") if `beg_dot'~=0 { local strippedname = substr(`"`save'"',1,`=`beg_dot'-1') } else { local strippedname `"`save'"' } } } qui { if `"`using'"'~="" { preserve qui insheet using `"`using'"', noname clear } *foreach var of varlist _all { * tostring `var', replace force *} stringMaker if "`dec'"~="" { * apply decimals foreach var of varlist _all { local N=_N forval num=1/`N' { local content=`var'[`num'] capture confirm number `content' if _rc==0 { * only if a number replace `var' = string(`content',"%12.`dec'fc") in `num' } else { * only if not a number *replace `var'=`"`content'"' in `num' } } } } if "`noauto'"~="noauto" & "`dec'"=="" { * apply autodigits foreach var of varlist _all { local N=_N forval num=1/`N' { local content=`var'[`num'] capture confirm number `content' if _rc==0 { * only if a number autodigits2 `content' `auto' `less' replace `var' = string(`content',"%12.`r(valstr)'") in `num' } else { * only if not a number *replace `var'=`"`content'"' in `num' } } } } if ("`nohead'"~="nohead" & `"`using'"'=="") | "`head'"=="head" { * moves the variable names down local N=_N+1 tempvar id gen `id'=_n set obs `N' replace `id'=0 in `N' sort `id' drop `id' local num 1 foreach var of varlist _all { replace `var'="`var'" in 1 } } * needs to be renamed regardless local num 1 foreach var of varlist _all { ren `var' v`num' local num=`num'+1 } *** dta file thing if "`dta'"=="dta" { cap confirm file `"`strippedname'.dta"' if !_rc & "`replace'"~="replace" { * it exists noi di in red `"`strippedname'.dta exists; specify {opt replace}"' exit 198 } save `"`strippedname'"', replace *local usingTerm `"`strippedname'.dta"' *local cl `"{browse logout, seefile(`"`usingTerm'"'):`usingTerm'}"' *noi di as txt `"`cl'"' } *** Excel xml file thing if "`excel'"=="excel" { tempfile file1 cap confirm file `"`strippedname'.xml"' if !_rc & "`replace'"~="replace" { * it exists noi di in red `"`strippedname'.xml exists; specify {opt replace}"' exit 198 } save `file1', replace if "`raw'"=="raw" { replace raw=`"""' + raw + `"""' } local titleWide 0 local headBorder 1 local N=_N local bottomBorder `N' *use `outing',clear * _xmlout using `"`strippedname'"', excelFile(`excelFile') nonames titleWide(`titleWide') /* * */ headBorder(`headBorder') bottomBorder(`bottomBorder') local N=_N _xmlout using `"`strippedname'"', nonames headBorder(1) bottomBorder(`N') local usingTerm `"`strippedname'.xml"' local cl `"{browse `"`usingTerm'"'}"' noi di as txt `"`cl'"' use `file1', clear } if "`word'"=="word" | "`tex'"=="tex" { cap preserve if ("`nohead'"=="nohead" & `"`using'"'~="") & "`head'"~="head" { * `using' indicates * files not yet named v* local num 1 foreach var of varlist _all { ren `var' v`num' local num=`num'+1 } } *** Word rtf file thing if "`word'"=="word" { cap confirm file `"`strippedname'.rtf"' if !_rc & "`replace'"~="replace" { * it exists noi di in red `"`strippedname'.rtf exists; specify {opt replace}"' exit 198 } local titleWide 0 local headBorder 2 local N=_N local bottomBorder `N' local totrows `N' * there must be varlist to avoid error *_wordout v* `"`using'"', titleWide(`titleWide') headBorder(`headBorder') bottomBorder(`bottomBorder') replace nopretty _wordout v* using `"`strippedname'"', wordFile(`wordFile') titleWide(`titleWide') /* */ headBorder(`headBorder') bottomBorder(`bottomBorder') replace nopretty local temp `r(documentname)' * strip off "using" and quotes gettoken part rest: temp, parse(" ") gettoken usingTerm second: rest, parse(" ") local cl_word `"{browse `"`usingTerm'"'}"' noi di as txt `"`cl_word'"' } *** LaTeX thing *** (will mess up the original file) if "`tex'"=="tex" { local titleWide 0 local headBorder 1 local N=_N local bottomBorder `N' cap confirm file `"`strippedname'.tex"' if !_rc & "`replace'"~="replace" { * it exists noi di in red `"`strippedname'.tex exists; specify {opt replace}"' exit 198 } * make certain `1' is not `"`using'"' (another context) _texout v* using `"`strippedname'"', texFile(`texFile') titleWide(`titleWide') headBorder(`headBorder') bottomBorder(`bottomBorder') `texopts' replace if `"`texFile'"'=="" { local endName "tex" } else { local endName "`texFile'" } local usingTerm `"`strippedname'.`endName'"' local cl_tex `"{browse `"`usingTerm'"'}"' noi di as txt `"`cl_tex'"' } } } /* quietly */ end ******************************************************************************************** *** ripped from outreg2 Mar 2008 program define autodigits2, rclass version 7.0 * getting the significant digits args input auto less if `input'~=. { local times=0 local left=0 * integer checked by modified mod function if round((`input' - int(`input')),0.0000000001)==0 { local whole=1 } else { local whole=0 * non-interger if `input'<. { * digits that need to be moved if it were only decimals: take the ceiling of log 10 of absolute value of decimals local times=abs(int(ln(abs(`input'-int(`input')))/ln(10)-1)) * the whole number: take the ceiling of log 10 of absolute value local left=int(ln(abs(`input'))/ln(10)+1) } } * assign the fixed decimal values into aadec if `whole'==1 { local aadec=0 } else if .>`left' & `left'>0 { * reduce the left by one if more than zero to accept one extra digit if `left'<=`auto' { local aadec=`auto'-`left'+1 } else { local aadec=0 } } else { local aadec=`times'+`auto'-1 } if "`less'"=="" { * needs to between 0 and 11 if `aadec'<0 { local aadec=0 } *if `aadec'<11 { if `aadec'<7 { * use fixed local valstr "`aadec'f" } else { * use exponential local valstr "`=`auto'-1'e" } } else { * needs to between 0 and 11 local aadec=`aadec'-`less' if `aadec'<0 { local aadec=0 } *if `aadec'<10 { if `aadec'<7 { * use fixed local valstr "`aadec'f" } else { * use exponential local valstr "`=`auto'-1'e" } } * make it exponential if too big if `input'>1000000 & `input'<. { local valstr "`=`auto'-0'e" } * make it exponential if too negative (small) if `input'<-1000000 & `input'<. { local valstr "`=`auto'-0'e" } return scalar value=`aadec' return local valstr="`valstr'" } else { * it is a missing value return scalar value=. return local valstr="missing" } end ******************************************************************************************** * ripped from outreg2 on Apr2009 * 27oct2009 nopretty fixed program define _texout, sortpreserve * based on out2tex version 0.9 4oct01 by john_gallup@alum.swarthmore.edu version 7.0 * add one if only one v* column exists unab list: v* local count: word count `list' if `count'==1 { gen str v2="" order v* } if `count'==0 { exit } if "`1'" == "using" { syntax using/ [, texFile(string) Landscape Fragment NOPRetty PRetty /* */ Fontsize(numlist integer max=1 >=10 <=12) noBorder Cellborder /* */ Appendpage noPAgenum a4 a5 b5 LETter LEGal EXecutive replace /* */ Fast ] if "`pretty'"=="pretty" { local nopretty "" } if "`fast'" == "" { preserve } loadout using `"`using'"', clear local numcol = `r(numcol)' local titleWide = `r(titleWide)' local headBorder = `r(headBorder)' local bottomBorder = `r(bottomBorder)' local totrows = _N local varname "v1" unab statvars : v2-v`numcol' } else { syntax varlist using/, titleWide(int) headBorder(int) bottomBorder(int) /* */ [texFile(string) TOtrows(int 0) Landscape Fragment NOPRetty PRetty /* */ Fontsize(numlist integer max=1 >=10 <=12) noBorder Cellborder /* */ Appendpage noPAgenum a4 a5 b5 LETter LEGal EXecutive replace ] if `totrows'==0 { local totrows = _N } local numcols : word count `varlist' gettoken varname statvars : varlist local fast 1 } if "`pretty'"=="pretty" { local pretty "" } else { local pretty "NOT PRETTY AT ALL" } local colhead1 = `titleWide' + 1 local strow1 = `headBorder' + 1 * insert $<$ to be handled in LaTeX conversion local N=_N forval num=`bottomBorder'/`N' { local temp=v1[`num'] tokenize `"`temp'"', parse (" <") local count 1 local newTex "" local noSpace 0 while `"``count''"'~="" { if `"``count''"'=="<" { local `count' "$<$" local newTex `"`newTex'``count''"' local noSpace 1 } else { if `noSpace'~=1 { local newTex `"`newTex' ``count''"' } else { local newTex `"`newTex'``count''"' local noSpace 0 } } local count=`count'+1 } replace v1=`"`newTex'"' in `num' } *** replace if equation column present count if v1=="EQUATION" if `r(N)'~=0 { tempvar myvar * use v2 instead replace v1 = v2 in `=`bottomBorder'+1'/`totrows' replace v2 = "" in `=`bottomBorder'+1'/`totrows' * change the string length gen str5 `myvar' ="" replace `myvar' =v2 drop v2 ren `myvar' v2 order v1 v2 } /* if file extension specified in `"`using'"', replace it with ".tex" for output local next_dot = index(`"`using'"', ".") if `next_dot' { local using = substr("`using'",1,`=`next_dot'-1') } */ if `"`texFile'"'=="" { local endName "tex" } else { local endName "`texFile'" } local using `"using "`using'.`endName'""' local fsize = ("`fontsize'" != "") if `fsize' { local fontsize "`fontsize'pt" } local lscp = ("`landscape'" != "") if (`lscp' & `fsize') { local landscape ",landscape" } local pretty = ("`pretty'" == "") local cborder = ("`cellborder'" != "") local noborder = ("`border'" != "") local nopagen = ("`pagenum'" != "") local nofrag = ("`fragment'" == "") if `cborder' & `noborder' { di in red "may not specify both cellborder and noborder options" exit 198 } local nopt : word count `a4' `a5' `b5' `letter' `legal' `executive' if `nopt' > 1 { di in red "choose only one of a4, a5, b5, letter, legal, executive" exit 198 } local pagesize "`a4'`a5'`b5'`letter'`legal'`executive'" if "`pagesize'"=="" | "`letter'"!="" { local pwidth "8.5in" local pheight "11in" } else if "`legal'"!="" { local pwidth "8.5in" local pheight "14in" } else if "`executive'"!="" { local pwidth "7.25in" local pheight "10.5in" } else if "`a4'"!="" { local pwidth "210mm" local pheight "297mm" } else if "`a5'"!="" { local pwidth "148mm" local pheight "210mm" } else if "`b5'"!="" { local pwidth "176mm" local pheight "250mm" } if `lscp' { local temp "`pwidth'" local pwidth "`pheight'" local pheight "`temp'" } if "`pagesize'"!="" { local pagesize "`pagesize'paper" if (`lscp' | `fsize') { local pagesize ",`pagesize'" } } if `cborder' & `noborder' { di in red "may not specify both cellborder and noborder options" exit 198 } quietly { tempvar has_eqn st2_row last_st pad0 pad1 pad2_n padN order * replace % with \%, and _ with \_ if <2 $'s (i.e. not an inline equation: $...$ * has_eqn indicates that varname has 2+ $'s gen byte `has_eqn' = index(`varname',"$") * make sure there are 2+ "$" in varname replace `has_eqn' = index(substr(`varname',`has_eqn'+1,.),"$")>0 if `has_eqn'>0 replace `varname'= subinstr(`varname',"_", "\_", .) if !`has_eqn' replace `varname'= subinstr(`varname',"%", "\%", .) if `pretty' { replace `varname'= subinword(`varname',"R-squared", "\$R^2$", 1) in `strow1'/`bottomBorder' replace `varname'= subinstr(`varname'," t stat", " \em t \em stat", 1) in `bottomBorder'/`totrows' replace `varname'= subinstr(`varname'," z stat", " \em z \em stat", 1) in `bottomBorder'/`totrows' } foreach svar of local statvars { /* make replacements for column headings rows of statvars */ replace `has_eqn' = index(`svar',"$") in `colhead1'/`headBorder' replace `has_eqn' = index(substr(`svar',`has_eqn'+1,.),"$")>0 in `colhead1'/`headBorder' if `has_eqn'>0 replace `svar'= subinstr(`svar',"_", "\_", .) in `colhead1'/`headBorder' if !`has_eqn' replace `svar'= subinstr(`svar',"%", "\%", .) in `colhead1'/`headBorder' /* replace <, >, {, }, | with $<$, $>$, \{, \}, and $|$ in stats rows */ /* which can be used as brackets by outstat */ replace `svar'= subinstr(`svar',"<", "$<$", .) in `strow1'/`bottomBorder' replace `svar'= subinstr(`svar',">", "$>$", .) in `strow1'/`bottomBorder' replace `svar'= subinstr(`svar',"{", "\{", .) in `strow1'/`bottomBorder' replace `svar'= subinstr(`svar',"}", "\}", .) in `strow1'/`bottomBorder' replace `svar'= subinstr(`svar',"|", "$|$", .) in `strow1'/`bottomBorder' } if `pretty' { /* make title fonts large; notes & t stats small */ local blarge "\begin{large}" local elarge "\end{large}" local bfnsize "\begin{footnotesize}" local efnsize "\end{footnotesize}" } if `cborder' { local vline "|" } gen str20 `pad0' = "" gen str20 `padN' = "" if `titleWide' { replace `pad0' = "\multicolumn{`numcols'}{`vline'c`vline'}{`blarge'" in 1 / `titleWide' replace `padN' = "`elarge'} \\\" in 1 / `titleWide' } if `bottomBorder' < `totrows' { local noterow1 = `bottomBorder' + 1 replace `pad0' = "\multicolumn{`numcols'}{`vline'c`vline'}{`bfnsize'" in `noterow1' / l replace `padN' = "`efnsize'} \\\" in `noterow1' / l } gen str3 `pad1' = " & " in `colhead1' / `bottomBorder' if `numcols' > 2 { gen str3 `pad2_n' = `pad1' } if `pretty' { /* make stats 2-N small font */ local strow1 = `headBorder' + 1 gen byte `st2_row' = 0 replace `st2_row' = (trim(`varname') == "") in `strow1' / `bottomBorder' /* only stats 2+ */ gen byte `last_st' = (`st2_row' & `varname'[_n+1] != "") /* last stats row */ if !`cborder' { replace `pad0' = "\vspace{4pt}" if `last_st' } replace `pad1' = `pad1' + "`bfnsize'" if `st2_row' if `numcols' > 2 { replace `pad2_n' = "`efnsize'" + `pad2_n' + "`bfnsize'" if `st2_row' } replace `padN' = "`efnsize'" if `st2_row' } replace `padN' = `padN' + " \\\" in `colhead1' / `bottomBorder' if `cborder' { replace `padN' = `padN' + " \hline" } else { if !`noborder' { if `headBorder' { if `titleWide' { replace `padN' = `padN' + " \hline" in `titleWide' } replace `padN' = `padN' + " \hline" in `headBorder' } replace `padN' = `padN' + " \hline" in `bottomBorder' } } local vlist "`pad0' `varname' `pad1'" tokenize `statvars' local ncols_1 = `numcols' - 1 local ncols_2 = `ncols_1' - 1 forvalues v = 1/`ncols_2' { local vlist "`vlist' ``v'' `pad2_n'" } local vlist "`vlist' ``ncols_1'' `padN'" local texheadfootrows = `nofrag' + `pretty' + 1 /* in both headers and footers */ local texheadrow = 2 * `nofrag' + `nopagen' + `texheadfootrows' local texfootrow = `texheadfootrows' local newtotrows = `totrows' + `texheadrow' + `texfootrow' if `newtotrows' > _N { local oldN = _N set obs `newtotrows' } else { local oldN = 0 } gen long `order' = _n + `texheadrow' in 1 / `totrows' local newtexhrow1 = `totrows' + 1 local newtexhrowN = `totrows' + `texheadrow' replace `order' = _n - `totrows' in `newtexhrow1' / `newtexhrowN' sort `order' * insert TeX header lines local ccc : display _dup(`ncols_1') "`vline'c" if `nofrag' { replace `pad0' = "\documentclass[`fontsize'`landscape'`pagesize']{article}" in 1 replace `pad0' = "\setlength{\pdfpagewidth}{`pwidth'} \setlength{\pdfpageheight}{`pheight'}" in 2 replace `pad0' = "\begin{document}" in 3 replace `pad0' = "\end{document}" in `newtotrows' } if `nopagen' { local row = `texheadrow' - 1 - `pretty' replace `pad0' = "\thispagestyle{empty}" in `row' } if `pretty' { local row = `texheadrow' - 1 replace `pad0' = "\begin{center}" in `row' local row = `newtotrows' - `texfootrow' + 2 replace `pad0' = "\end{center}" in `row' } local row = `texheadrow' replace `pad0' = "\begin{tabular}{`vline'l`ccc'`vline'}" in `row' if (!`titleWide' | `cborder') & !`noborder' { replace `pad0' = `pad0' + " \hline" in `row' } local row = `newtotrows' - `texfootrow' + 1 replace `pad0' = "\end{tabular}" in `row' outfile `vlist' `using' in 1/`newtotrows', `replace' runtogether * delete new rows created for TeX table, if any if `oldN' { keep in 1/`totrows' } } /* quietly */ end /* end _texout */ ******************************************************************************************** * ripped from outreg2 on Mar2009 program define _wordout, sortpreserve rclass version 7.0 * based on version 0.9 4oct01 by john_gallup@alum.swarthmore.edu if "`1'" == "using" { syntax using/ [, wordFile(string) Landscape Fragment noPRetty /* */ Fontsize(numlist max=1 >0) noBorder Cellborder /* */ Appendpage PAgesize(string) /* */ Lmargin(numlist max=1 >=0.5) Rmargin(numlist max=1 >=0.5) /* */ Tmargin(numlist max=1 >=0.5) Bmargin(numlist max=1 >=0.5) /* */ replace Fast] if "`fast'" == "" {preserve} loadout using `"`using'"', clear local numcol = `r(numcol)' local titleWide = `r(titleWide)' local headBorder = `r(headBorder)' local bottomBorder = `r(bottomBorder)' local totrows = _N local varname "v1" unab statvars : v2-v`numcol' } else { syntax varlist using/, titleWide(int) headBorder(int) bottomBorder(int) /* */ [wordFile(string) TOtrows(int 0) Landscape Fragment noPRetty /* */ Fontsize(numlist max=1 >0) noBorder Cellborder /* */ Appendpage PAgesize(string) /* */ Lmargin(numlist max=1 >=0.5) Rmargin(numlist max=1 >=0.5) /* */ Tmargin(numlist max=1 >=0.5) Bmargin(numlist max=1 >=0.5) /* */ replace] if `totrows'==0 { local totrows = _N } local numcols : word count `varlist' gettoken varname statvars : varlist local fast 1 } local colhead1 = `titleWide' + 1 local strow1 = `headBorder' + 1 *** replace if equation column present local hack 0 count if v1=="EQUATION" if `r(N)'~=0 { * use v2 instead replace v1 = v2 in `=`bottomBorder'+1'/`totrows' replace v2 = "" in `=`bottomBorder'+1'/`totrows' * change the string length gen str5 myvar ="" replace myvar =v2 drop v2 ren myvar v2 order v1 v2 local hack 1 } /* if file extension specified in `"`using'"', replace it with ".rtf" for output local next_dot = index(`"`using'"', ".") if `next_dot' { local using = substr(`"`using'"',1,`=`next_dot'-1') } */ if `"`wordFile'"'=="" { local endName "rtf" } else { local endName "`wordFile'" } local using `"using "`using'.`endName'""' return local documentname `"`using'"' if "`fontsize'" == "" { local fontsize "12" } local lscp = ("`landscape'" != "") local pretty = ("`pretty'" == "") local cborder = ("`cellborder'" != "") local noborder = ("`border'" != "") local stdborder = (!`noborder' & !`cborder') local nopagen = ("`pagenum'" != "") local nofrag = ("`fragment'" == "") if `cborder' & !`noborder' { di in red "may not specify both cellborder and noborder options" exit 198 } * reformat "R-squared" and italicize "t" or "z" if `pretty' { quietly { replace `varname'= subinword(`varname',"R-squared", "{\i R{\super 2}}", 1) in `strow1'/`bottomBorder' replace `varname'= subinstr(`varname'," t stat", " {\i t} stat", 1) in `bottomBorder'/`totrows' replace `varname'= subinstr(`varname'," z stat", " {\i z} stat", 1) in `bottomBorder'/`totrows' } } * font sizes in points*2 local font2 = int(`fontsize'*2) if `pretty' { /* make title fonts large; notes & t stats small */ local fslarge = "\fs" + string(int(`font2' * 1.2)) local fsmed = "\fs" + string(`font2') local fssmall = "\fs" + string(int(`font2' * 0.8)) local sa0 "\sa0" /* put space after t stats rows */ local gapsize = int(`fontsize'*0.4*20) /* 40% of point size converted to twips */ local sa_gap "\sa`gapsize'" } else { local fs0 = "\fs" + string(`font2') } local onecolhead = (`headBorder' - `titleWide' == 1) /* onecolhead = true if only one row of column headings */ if `stdborder' { if !`onecolhead' { * runs here *local trbrdrt "\clbrdrt\brdrs" /* table top is overlined */ *local trbrdrt "\trbrdrt\brdrs" /* table top is overlined */ local clbrdr_uo "\clbrdrt\brdrs" /* cells are overlined */ local clbrdr_ul "\clbrdrb\brdrs" /* cells are underlined */ } else { /* cells are over- and underlined */ local clbrdr_ul "\clbrdrt\brdrs\clbrdrb\brdrs" } local trbrdrb "\trbrdrb\brdrs" } if `cborder' { /* if !cborder then clbrdr is blank */ local clbrdr "\clbrdrt\brdrs\clbrdrb\brdrs\clbrdrl\brdrs\clbrdrr\brdrs" } * figure out max str widths to make cell boundaries * cell width in twips = (max str width) * (pt size) * 12 * (12 found by trial and error) local twipconst = int(`fontsize' * 12 ) tempvar newvarname qui gen str80 `newvarname' = `varname' in `strow1'/`bottomBorder' local newvarlist "`newvarname' `statvars'" qui compress `newvarlist' local cellpos = 0 foreach avar of local newvarlist { local strwidth : type `avar' local strwidth = subinstr("`strwidth'", "str", "", .) local strwidth = `strwidth' + 1 /* add buffer */ local cellpos = `cellpos' + `strwidth'*`twipconst' * hacking if `hack'==1 & "`avar'"=="`newvarname'" & `cellpos'<1350 { local cellpos=1350 } local clwidths "`clwidths'`clbrdr'\cellx`cellpos'" * put in underline at bottom of header in clwidth_ul local clwidth_ul "`clwidth_ul'`clbrdr_ul'\cellx`cellpos'" * put in overline local clwidth_ol "`clwidth_ol'`clbrdr_uo'\cellx`cellpos'" } if `stdborder' { if `onecolhead' { local clwidth1 "`clwidth_ul'" } else { local clwidth1 "`clwidths'" local clwidth2 "`clwidth_ul'" } local clwidth3 "`clwidths'" } else{ local clwidth1 "`clwidths'" } * statistics row formatting tempvar prettyfmt qui gen str12 `prettyfmt' = "" /* empty unless `pretty' */ if `pretty' { * make stats 2-N small font tempvar st2_row last_st quietly { gen byte `st2_row' = 0 replace `st2_row' = (trim(`varname') == "") in `strow1' / `bottomBorder' /* only stats 2+ */ gen byte `last_st' = (`st2_row' & `varname'[_n+1] != "") /* last stats row */ replace `prettyfmt' = "`sa0'" in `strow1' / `bottomBorder' replace `prettyfmt' = "`sa_gap'" if `last_st' in `strow1' / `bottomBorder' replace `prettyfmt' = `prettyfmt' + "`fsmed'" if !`st2_row' in `strow1' / `bottomBorder' replace `prettyfmt' = `prettyfmt' + "`fssmall'" if `st2_row' in `strow1' / `bottomBorder' } } * create macros with file write contents forvalues row = `colhead1'/`bottomBorder' { local svarfmt`row' `"(`prettyfmt'[`row']) "\ql " (`varname'[`row']) "\cell""' foreach avar of local statvars { local svarfmt`row' `"`svarfmt`row''"\qc " (`avar'[`row']) "\cell""' } local svarfmt`row' `"`svarfmt`row''"\row" _n"' } * write file tempname rtfile file open `rtfile' `using', write `replace' file write `rtfile' "{\rtf1`fs0'" _n /* change if not roman: \deff0{\fonttbl{\f0\froman}} */ * title if `titleWide' { file write `rtfile' "\pard\qc`fslarge'" _n forvalues row = 1/`titleWide' { file write `rtfile' (`varname'[`row']) "\par" _n } } * The top line file write `rtfile' "\trowd\trgaph75\trleft-75\intbl\trqc`fsmed'`trbrdrt'`clwidth_ol'" _n *file write `rtfile' "\trowd\trgaph75\trleft-75\intbl\trqc`fsmed'`trbrdrt'`clwidth1'" _n local headBorder_1 = `headBorder' - 1 * write header rows 1 to N-1 forvalues row = `colhead1'/`headBorder_1' { file write `rtfile' `svarfmt`row'' * turn off the overlining the first time it's run file write `rtfile' "\trowd\trgaph75\trleft-75\trqc`clwidth3'" _n } file write `rtfile' "\trowd\trgaph75\trleft-75\trqc`clwidth2'" _n * write last header row file write `rtfile' `svarfmt`headBorder'' local bottomBorder_1 = `bottomBorder' - 1 /* turn off cell underlining */ file write `rtfile' "\trowd\trgaph75\trleft-75\trqc`clwidth3'" _n * table contents forvalues row = `strow1'/`bottomBorder_1' { file write `rtfile' `svarfmt`row'' } if `stdborder' { /* write last row */ *file write `rtfile' "\trowd\trgaph75\trleft-75\trqc`trbrdrb'`clwidths'" _n * make it underline file write `rtfile' "\trowd\trgaph75\trleft-75\trqc`trbrdrb'`clwidth_ul'" _n file write `rtfile' `svarfmt`bottomBorder'' } /* write notes rows */ if `bottomBorder' < `totrows' { local noterow1 = `bottomBorder' + 1 file write `rtfile' "\pard\qc`fssmall'" _n forvalues row = `noterow1'/`totrows' { file write `rtfile' (`varname'[`row']) "\par" _n } } * write closing curly bracket file write `rtfile' "}" end /* end _wordout */ ******************************************************************************************** * ripped from outreg2 on Mar2009 program define _xmlout version 7.0 versionSet version `version' * emulates the output produced by xmlsave: * xmlsave myfile, replace doctype(excel) legible syntax using/ [, excelFile(string) LEGible noNAMes titleWide(integer 0) /* */ headBorder(integer 10) bottomBorder(integer 10) ] * assumes all columns are string; if numbers, then the format needs to be checked *local legible legible if "`legible'"=="legible" { local _n "_n" } tempname source saving if `"`excelFile'"'=="" { local endName "xml" } else { local endName "`excelFile'" } local save `"`using'.`endName'"' *file open `source' using `"`using'"', read file open `saving' using `"`save'"', write text replace *file write `saving' `"`macval(line)'"' file write `saving' `"<?xml version="1.0" encoding="US-ASCII" standalone="yes"?>"' `_n' file write `saving' `"<?mso-application progid="Excel.Sheet"?>"' `_n' file write `saving' `"<Workbook xmlns="urn:schemas-microsoft-com:office:spreadsheet""' `_n' file write `saving' `" xmlns:o="urn:schemas-microsoft-com:office:office""' `_n' file write `saving' `" xmlns:x="urn:schemas-microsoft-com:office:excel""' `_n' file write `saving' `" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet""' `_n' file write `saving' `" xmlns:html="http://www.w3.org/TR/REC-html40">"' `_n' file write `saving' `"<DocumentProperties xmlns="urn:schemas-microsoft-com:office:office">"' `_n' file write `saving' `"<Author></Author>"' `_n' file write `saving' `"<LastAuthor></LastAuthor>"' `_n' file write `saving' `"<Created></Created>"' `_n' file write `saving' `"<LastSaved></LastSaved>"' `_n' file write `saving' `"<Company></Company>"' `_n' file write `saving' `"<Version></Version>"' `_n' file write `saving' `"</DocumentProperties>"' `_n' file write `saving' `"<ExcelWorkbook xmlns="urn:schemas-microsoft-com:office:excel">"' `_n' file write `saving' `"<ProtectStructure>False</ProtectStructure>"' `_n' file write `saving' `"<ProtectWindows>False</ProtectWindows>"' `_n' file write `saving' `"</ExcelWorkbook>"' `_n' file write `saving' `"<Styles>"' `_n' * styles file write `saving' `"<Style ss:ID="Default" ss:Name="Normal">"' `_n' file write `saving' `"<Alignment ss:Vertical="Bottom"/>"' `_n' file write `saving' `"<Borders/>"' `_n' file write `saving' `"<Font/>"' `_n' file write `saving' `"<Interior/>"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"<Protection/>"' `_n' file write `saving' `"</Style>"' `_n' * bold & (center) file write `saving' `"<Style ss:ID="s1">"' `_n' *file write `saving' `"<Alignment ss:Horizontal="Center" ss:Vertical="Bottom"/>"' `_n' file write `saving' `"<Font ss:Bold="1" ss:Size='12'/>"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"</Style>"' `_n' * top border & center file write `saving' `"<Style ss:ID="s21">"' `_n' file write `saving' `"<Alignment ss:Horizontal="Center" ss:Vertical="Bottom"/>"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"<Borders>"' `_n' file write `saving' `"<Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/>"' `_n' file write `saving' `"</Borders>"' `_n' file write `saving' `"</Style>"' `_n' * main body (no border) & center file write `saving' `"<Style ss:ID="s22">"' `_n' file write `saving' `"<Alignment ss:Horizontal="Center" ss:Vertical="Bottom"/>"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"</Style>"' `_n' * bottom border & center file write `saving' `"<Style ss:ID="s23">"' `_n' file write `saving' `"<Alignment ss:Horizontal="Center" ss:Vertical="Bottom"/>"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"<Borders>"' `_n' file write `saving' `"<Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/>"' `_n' file write `saving' `"</Borders>"' `_n' file write `saving' `"</Style>"' `_n' * goldfish (no border, left-justified) file write `saving' `"<Style ss:ID="s24">"' `_n' file write `saving' `"<NumberFormat/>"' `_n' file write `saving' `"</Style>"' `_n' * top border file write `saving' `"<Style ss:ID="s31">"' `_n' file write `saving' `"<Borders>"' `_n' file write `saving' `"<Border ss:Position="Top" ss:LineStyle="Continuous" ss:Weight="1"/>"' `_n' file write `saving' `"</Borders>"' `_n' file write `saving' `"</Style>"' `_n' * main body (no border) file write `saving' `"<Style ss:ID="s32">"' `_n' file write `saving' `"<Borders/>"' `_n' file write `saving' `"</Style>"' `_n' * bottom border & center file write `saving' `"<Style ss:ID="s33">"' `_n' file write `saving' `"<Borders>"' `_n' file write `saving' `"<Border ss:Position="Bottom" ss:LineStyle="Continuous" ss:Weight="1"/>"' `_n' file write `saving' `"</Borders>"' `_n' file write `saving' `"</Style>"' `_n' file write `saving' `"</Styles>"' `_n' file write `saving' `"<Names>"' `_n' file write `saving' `"</Names>"' `_n' file write `saving' `"<Worksheet ss:Name="Sheet1">"' `_n' * set up file size qui describe, short local N=_N local tableN `N' if "`names'"~="nonames" { * add one if variable names are to be inserted local tableN=`N'+1 } else { * add one for the look local tableN=`N'+1 } file write `saving' `"<Table ss:ExpandedColumnCount="`r(k)'" ss:ExpandedRowCount="`tableN'""' `_n' file write `saving' `" x:FullColumns="1" x:FullRows="1">"' `_n' * should be tostring and format here if dealing with numbers ds8 * write the variable names at the top or empty row if "`names'"~="nonames" { file write `saving' `"<Row>"' `_n' foreach var in `dsVarlist' { if "`Version7'"~="" { file write `saving' `"<Cell ss:StyleID="s1"><Data ss:Type="String">`macval(var)'</Data></Cell>"' _n } else { file write `saving' `"<Cell ss:StyleID="s1"><Data ss:Type="String">`var'</Data></Cell>"' _n } } file write `saving' `"</Row>"' `_n' } else { file write `saving' `"<Row>"' `_n' file write `saving' `"</Row>"' `_n' } * title local count `titleWide' local total 1 while `count'~=0 { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`total') n(`N') style(`" ss:StyleID="s1""') style1(`" ss:StyleID="s1""') local count=`count'-1 local total=`total'+1 } * top border local count=`total' forval num=`count'/`count' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s21""') style1(`" ss:StyleID="s31""') local total=`total'+1 } * ctitle local count=`total' forval num=`count'/`headBorder' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s22""') style1(`" ss:StyleID="s32""') local total=`total'+1 } * top border (closes ctitle) local count=`total' forval num=`count'/`count' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s21""') style1(`" ss:StyleID="s31""') local total=`total'+1 } * body local count=`total' forval num=`count'/`=`bottomBorder'-1' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s22""') style1(`" ss:StyleID="s32""') local total=`total'+1 } * bottom border (closes body) local count=`total' forval num=`count'/`count' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s23""') style1(`" ss:StyleID="s33""') local total=`total'+1 } * goldfish if `N'>`total' { local count=`total' forval num=`count'/`N' { xmlstack, saving(`saving') dsVarlist(`dsVarlist') num(`num') n(`N') style(`" ss:StyleID="s24""') style1(`" ss:StyleID="s24""') local total=`total'+1 } } /* forval num=1/`N' { file write `saving' `"<Row>"' `_n' *foreach var in `=r(varlist)' { foreach var in `dsVarlist' { *local stuff `=`var'[`num']' local stuff=`var' in `num' local stuff : subinstr local stuff "<" "<", all local stuff : subinstr local stuff ">" ">", all * the main body if "`Version7'"~="" { file write `saving' `"<Cell`style'><Data ss:Type="String">`macval(stuff)'</Data></Cell>"' `_n' } else { file write `saving' `"<Cell`style'><Data ss:Type="String">`stuff'</Data></Cell>"' `_n' } } file write `saving' `"</Row>"' `_n' } */ file write `saving' `"</Table>"' `_n' file write `saving' `"<WorksheetOptions xmlns="urn:schemas-microsoft-com:office:excel">"' `_n' file write `saving' `"<ProtectedObjects>False</ProtectedObjects>"' `_n' file write `saving' `"<ProtectedScenarios>False</ProtectedScenarios>"' `_n' file write `saving' `"</WorksheetOptions>"' `_n' file write `saving' `"</Worksheet>"' `_n' file write `saving' `"</Workbook>"' `_n' * close out with the last line *file write `saving' _n *file close `source' file close `saving' end /* _xmlout */ ******************************************************************************************** * ripped from outreg2 on Mar2009 program define xmlstack syntax, saving(string) dsVarlist(string) num(numlist) n(numlist) style(string) style1(string) local N `n' *forval num=1/`N' { file write `saving' `"<Row>"' `_n' local count 0 *foreach var in `=r(varlist)' { foreach var in `dsVarlist' { if `count'==0 { local STYLE `"`style1'"' } else { local STYLE `"`style'"' } *local stuff `=`var'[`num']' local stuff=`var' in `num' local stuff : subinstr local stuff "<" "<", all local stuff : subinstr local stuff ">" ">", all * the main body if "`Version7'"~="" { file write `saving' `"<Cell`STYLE'><Data ss:Type="String">`macval(stuff)'</Data></Cell>"' `_n' } else { file write `saving' `"<Cell`STYLE'><Data ss:Type="String">`stuff'</Data></Cell>"' `_n' } local count=`count'+1 } file write `saving' `"</Row>"' `_n' *} end /* xmlstack */ ******************************************************************************************** *** ripped from outreg2 Mar 2009 program define ds8 * get you the list of variable like -ds- does for version 8 version 7.0 qui ds if "`r(varlist)'"=="" { local dsVarlist "" foreach var of varlist _all { local dsVarlist "`dsVarlist' `var'" } c_local dsVarlist `dsVarlist' } else { c_local dsVarlist `r(varlist)' } end ******************************************************************************************** program define stringMaker * makes a string out variables tempvar temp foreach var of varlist _all { cap confirm string var `var' if _rc { * not a string gen str2 `temp'="" replace `temp' = string(`var') move `var' `temp' drop `var' ren `temp' `var' } } end ******************************************************************************************** * cdout 1.0.1 Apr2009 by roywada@hotmail.com * opens the current directory for your viewing pleasure * the following disabled 14oct2009: cap winexec cmd /c start . * displays "current directory" instead of cdout or the folder location * displays dir" instead of cdout or the folder location program define _cdout cap version 7.0 *cap winexec cmd /c start . *cap !start cmd /c start . if _rc~=0 { * version 6 or earlier di `"{stata `"cdout"':dir}"' } else { * invisible to Stata 7 local Version7 local Version7 `c(stata_version)' if "`Version7'"=="" { * it is version 7 or earlier di `"{stata `"cdout"':dir}"' } else if `Version7'>=8.0 { version 8.0 di `"{browse `"`c(pwd)'"':dir}"' } } end ******************************************************************************************** * chewfile version 1.0.1 17Aug2009 by roywada@hotmail.com * quick and easy way to chew and digest excessive large ASCII file program define _chewfile version 8.0 syntax using/, [save(string) begin(numlist max=1) end(string) clear parse(string) replace semiclear] if `"`parse'"'=="" { local parse `"`=char(9)'"' } if "`begin'"=="" { local begin 1 } if "`end'"=="" { local end . } if "`clear'"=="" & `"`save'"'=="" { if "`semiclear'"=="" { noi di in red "must specify {opt clear} or {opt save( )} exit 198 } } if "`semiclear'"=="semiclear" { qui drop * qui set obs 0 } else if "`clear'"=="clear" { clear qui set obs 0 } if `"`save'"'=="" { tempfile dump local save `dump' } tempname fh outout local linenum = 0 file open `fh' using `"`using'"', read qui file open `outout' using `"`save'"', write `replace' file read `fh' line while r(eof)==0 { local linenum = `linenum' + 1 local addedRow 0 if `linenum'>=`begin' & `linenum'<=`end' { if `addedRow'==0 { qui set obs `=`=_N'+1' } *display %4.0f `linenum' _asis `"`macval(line)'"' file write `outout' `"`macval(line)'"' _n if "`clear'"=="clear" | "`semiclear'"=="semiclear" { tokenize `"`macval(line)'"', parse(`"`parse'"') local num 1 local colnum 1 while "``num''"~="" { local needOneMore 0 if `"``num''"'~=`"`parse'"' { cap gen str3 var`colnum'="" cap replace var`colnum'="``num''" in `linenum' if _rc~=0 { qui set obs `=`=_N'+1' cap replace var`colnum'="``num''" in `linenum' local addedRow 1 } *local colnum=`colnum'+1 } else { cap gen str3 var`colnum'="" local colnum=`colnum'+1 } local num=`num'+1 } } } file read `fh' line } file close `fh' file close `outout' end ******************************************************************************************** * 03nov2009, ripped from outreg2 on 05nov2009 prog define versionSet * sends back the version as c_local version 7.0 * invisible to Stata 7 cap local Version7 `c(stata_version)' c_local Version7 `Version7' if "`Version7'"=="" { * it is version 7 c_local version 7 } else if `Version7'>=8.2 { version 8.2 c_local version 8.2 } if "`Version7'"=="" { c_local bind "" } else { c_local bind "bind" } end exit * version 1.0.1 May2009 logout by roywada@hotmail.com cap no longer takes off the bottom line noauto auto( ) dec( ) hooked up _logfix split into _infix, unfinished logleft done, not implemented caplog has correct version control, enabling eret list value labels handled as proposed by Karl Keesman at sales@survey-design.com.au fix handles the horizontal lines *ssc de version 1.0.2 05May2009 logout by roywada@hotmail.com the bottomline no longer taken off by unwrap function the horizontal lines starting in the middle handled during delimited routine * version 1.0.3 14oct2009 fixed the compound quotes for `save' unwraps correctly (previously left an extra space) fixcut( ) option _cdout inserted _chewfile inserted range( ) option * 1.0.4 di before _cdout nopretty for _texout fixed?? versionSet error with fixcut( ) rectified _infix drop vertical lines before horizontal line needs work: logout, save(mytable) excel replace: eret list plus the ":" wipe or not user specified infix dataout circa Apr 2009 needs to be replaced with version 1.0.4 07sep2009