You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1125 lines
51 KiB
Plaintext
1125 lines
51 KiB
Plaintext
9 months ago
|
{smcl}
|
||
|
{* 14nov2009}{...}
|
||
|
{cmd:help outreg2}
|
||
|
|
||
|
{hline}
|
||
|
|
||
|
{title:Title}
|
||
|
|
||
|
{p2colset 5 16 22 2}{...}
|
||
|
{p2col :{hi: outreg2} {hline 2}}Arrange regression, summary, and tabulation outputs into an illustrative table{p_end}
|
||
|
{p2colset 5 16 22 2}{...}
|
||
|
{p2col :{hi: {help seeout}} {hline 2}}Opens a tab-delimited table in the data browser{p_end}
|
||
|
{p2colset 5 18 24 2}{...}
|
||
|
{p2col :{hi: {help shellout}} {hline 2}}Opens documents and their programs from inside Stata{p_end}
|
||
|
|
||
|
|
||
|
{title:Examples}
|
||
|
|
||
|
{help outreg2##s_0:0. Basic game plan} {help outreg2##s_11:11. Marginal Effects}
|
||
|
{help outreg2##s_1:1. Prefix and bys( )} {help outreg2##s_12:12. Word or Excel files}
|
||
|
{help outreg2##s_2:2. Running loops} {help outreg2##s_13:13. TeX files}
|
||
|
{help outreg2##s_3:3. Stored estimates} {help outreg2##s_14:14. Adding column titles or notes}
|
||
|
{help outreg2##s_4:4. Shorthand} {help outreg2##s_15:15. n-way cross-tabulation}
|
||
|
{help outreg2##s_5:5. Decimal places} {help outreg2##s_16:16. Group summary table}
|
||
|
{help outreg2##s_6:6. Sideway display} {help outreg2##s_17:17. Fixed effects or legends}
|
||
|
{help outreg2##s_7:7. Summary tables} {help outreg2##s_18:18. Insert r-class cmd( ) outputs}
|
||
|
{help outreg2##s_8:8. Drop/keep/order variables}
|
||
|
{help outreg2##s_9:9. Adding r( ) e( ) scalars}
|
||
|
{help outreg2##s_10:10. Odds ratios and rrr}
|
||
|
|
||
|
{p 4 4 6}{help outreg2##s_Differences:Different versions of {cmdab:outreg} and {cmdab:outreg2}}
|
||
|
|
||
|
{p2colreset}{...}
|
||
|
|
||
|
{hline}
|
||
|
|
||
|
{marker s_Description}
|
||
|
{title:Description}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
{cmd:outreg2} provides a fast and easy way to produce an illustrative table
|
||
|
of regression outputs. The regression outputs are produced piecemeal and are
|
||
|
difficult to compare without some type of rearrangement. {cmd:outreg2}
|
||
|
automates this process by concatenating the successive regression ouputs in a
|
||
|
vertical format. The resulting table is saved to the disk in ASCII
|
||
|
format, which can be read by other programs.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
{cmd:outreg2} thus facilitates the convertion of regression outputs to a standard
|
||
|
format suitable for inclusion in a scholarly publication. The functionality of outreg2
|
||
|
is based on the earlier package {help cmd:outreg}, by John Gallup. {help outreg2##s_Differences:Unlike}
|
||
|
{cmd:outreg}, {cmd:outreg2} is capable of writing LaTeX-format tables, as well as ASCII, MS Word
|
||
|
and MS Excel.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
{cmd:outreg2} can report any regression output, provided it conforms to
|
||
|
{it:the} {it:usual} {it:convention} for {help ereturn:ereturn list}. This includes
|
||
|
most regression commands in Stata 7 or later. {cmd:outreg2} will report the latest regression output
|
||
|
by default, or the list of {help estimates:stored estimates}. The ancillary statistics from from stored
|
||
|
{help return} can also be accessed using {opt e( )} or {opt adds:tat( )}.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
{cmd:outreg2} will also report the usual statistics such as standard error with the asterisks for the levels of
|
||
|
significance (1%, 5%, and 10%), t-statistics, p-values, the number of observations,
|
||
|
R-squareds, and the number of groups in a panel estimation. Standarized beta
|
||
|
coefficients, exponentially transformed coefficients (i.e. odds/risk ratios
|
||
|
or hazard rate). The user can add their own column titles with {opt ct:itle} and {opt addn:ote} options.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
An immediate access to the produced table is provided in the browser view with
|
||
|
{opt see} option. {cmd:outreg2} also comes with automatically formatted number of
|
||
|
significant digits, which avoids the awkward displays assoicated with the fixed
|
||
|
format.
|
||
|
|
||
|
|
||
|
{hline}
|
||
|
|
||
|
{marker s_Syntax}
|
||
|
{title:Syntax}
|
||
|
|
||
|
{synopt: Full syntax:}{p_end}
|
||
|
|
||
|
{p 6 8 6}
|
||
|
{cmdab:outreg2} [{varlist}] [{cmd:[}{help estimates:{it:estlist}}{cmd:]}]
|
||
|
{helpb using} {it:filename} [{cmd:,} {it:options}] [{cmd::} {help estimation commands:{it:command}}] {p_end}
|
||
|
|
||
|
{synopt: Shorthand:}{p_end}
|
||
|
|
||
|
{p 6 8 6}
|
||
|
{cmdab:outreg2} [{varlist}] [{cmd:[}{help estimates:{it:estlist}}{cmd:]}]
|
||
|
[{cmd:,} replace seeout]
|
||
|
[{cmd::} {help estimation commands:{it:command}}] {p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
where {it:command} takes one of {help estimation commands}. The shorthand works
|
||
|
only after a full syntax has been invoked.{p_end}
|
||
|
|
||
|
{p 4 6 2}
|
||
|
Note that {it:filename} must be enclosed within double quotes if it contains embedded spaces.{p_end}
|
||
|
|
||
|
|
||
|
{marker s_Options}
|
||
|
{title:Options}
|
||
|
|
||
|
{dlgtab:Main}
|
||
|
|
||
|
{phang}{opt replace} create a new file or overwrite the existing file.{p_end}
|
||
|
|
||
|
{phang}{opt see:out} display the regression table in the browser.{p_end}
|
||
|
|
||
|
{phang}{opt lab:el} replace variable names with variable labels.{p_end}
|
||
|
|
||
|
{phang}{cmd:label(insert)} insert labels next to variable names.{p_end}
|
||
|
|
||
|
{phang}{opt side:way} specify sideway display (with standard error next to coefficient). Use {opt paren( )}
|
||
|
or {opt noparen} to control the location of parentheses.{p_end}
|
||
|
|
||
|
{phang}{opt o:necol} specify one column to display multiple equations. The default is one
|
||
|
equation per column with the equation names separate from the variable names.{p_end}
|
||
|
|
||
|
{phang}{opt long} interweave the equation names into the same column
|
||
|
with the variable names column. Combine it with {opt text} if you want a converted
|
||
|
file in the text format as well. {p_end}
|
||
|
|
||
|
{phang}{opt ti:tle(list)} titles for your table; comma separated; use quotes for commas within a title.
|
||
|
Titles can be added at any time. To erase your title, encase a space between quotes like this: title(" "){p_end}
|
||
|
|
||
|
{phang}{opt ct:itle(list)} column titles; comma separated for each additonal row; use quotes if comma is part of title.
|
||
|
Example: ctitle("Wage, Participation","Wage: Participation"). To specify empty column title, specify
|
||
|
ctitle(" ").{p_end}
|
||
|
|
||
|
{phang}{opt cttop(list)} place additonal column titles on the top; comma separated, use quotes for multiple column titles.{p_end}
|
||
|
|
||
|
{phang}{opt addn:ote(list)} add your own notes at the bottom. Must be specified in the first {cmd:outreg2}
|
||
|
call when regression results are appended together. A blank line can be inserted by including "" as a note.{p_end}
|
||
|
|
||
|
{phang}{opt nonot:es} specifies that notes and legends explaining the standard errors, asterisks, etc., not be included.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Output Files}
|
||
|
|
||
|
{phang}{opt word} produces rich text file (rft) compatible with {cmd:MS Word}. The file conversion can be
|
||
|
specified at any time (you should do it with the last appedning). The existing file must not be open for
|
||
|
it to be written over.{p_end}
|
||
|
|
||
|
{phang}{opt excel} specifies an xml, xls, xlm, or cvs file compatible with a standard spreadsheet
|
||
|
like {cmd:MS Excel}. Any existing file with the same name must be closed to have it
|
||
|
replace with a new file.{p_end}
|
||
|
|
||
|
{phang}{opt text} produces plain text file exactly. {opt long} or {opt label} will
|
||
|
sometimes cause the main output text file to be different from what might be
|
||
|
expected. Use this option to obtain exactly specified text file.{p_end}
|
||
|
|
||
|
{phang}{opt tex} produces a stand-alone LaTeX compatible files suitable for loading into a TeX typesetting program
|
||
|
such as Scientific Word.{p_end}
|
||
|
|
||
|
{phang}{cmd:tex( )} takes the following options for tex:{p_end}
|
||
|
|
||
|
{p 8} {cmd:{ul:frag}}ment - a TeX fragment for inclusion in a larger document{p_end}
|
||
|
{p 8} {cmd:{ul:pr}}etty - with some italics and varying font sizes{p_end}
|
||
|
{p 8} {cmd:{ul:land}}scape - horizontally{p_end}
|
||
|
|
||
|
{phang}{opt quote} specifies quotation marks to encase each observation, which can
|
||
|
be helpful for reading the output file in other software. See the {opt noquote}
|
||
|
option in {help outsheet} for more details (all the output of {cmd:outreg2} comes
|
||
|
from string variables). {opt quote} may cause problems appending tables together. {p_end}
|
||
|
|
||
|
{phang}{opt comma} specifies that the ASCII file output be separated by commas
|
||
|
rather than by tabs. This can cause problems if any of the user-defined text has
|
||
|
commas in it (such as variable labels, {opt ct:itle}, {opt adds:tat}, or
|
||
|
{opt addn:ote}). If that is the case, consider using {opt quote} as well. {p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Auxiliary Statistics (for each variable)}
|
||
|
|
||
|
{phang}{opt st:ats( )} contains statistics to be reported per variable, the default is
|
||
|
{cmd:stats(coef se)}. Space- or comma-delimited. Restricted to the estimation sample (single equation). Choose
|
||
|
in any order or frequency from these:
|
||
|
|
||
|
{ul:regression}
|
||
|
coef se tstat pval ci ci_low
|
||
|
ci_high aster beta
|
||
|
|
||
|
{ul:summary}
|
||
|
N sum_w mean Var sd sum
|
||
|
min max skewness kurtosis p1 p5
|
||
|
p10 p25 p50 p75 p90 p95
|
||
|
p99
|
||
|
|
||
|
{ul:correlations}
|
||
|
corr pwcorr spearman
|
||
|
|
||
|
{ul:string}
|
||
|
blank
|
||
|
str({it:str}) where {it:str} is any string or numeric expression
|
||
|
|
||
|
{ul:command}
|
||
|
cmd({it:macro}:{it:cmd}) where {it:macro} is to be produced by any {help outreg2##s_18:{it:cmd}}
|
||
|
cmd({it:r( )}:{it:cmd}) where {it:r( )} is to be produced by any r-class {help outreg2##s_18:{it:cmd}}
|
||
|
|
||
|
|
||
|
{phang}{opt nose} specifies no standard error; only coefficients are reported {p_end}
|
||
|
|
||
|
{phang}{opt l:evel(integer)} specifies the confidence level, in percent, for
|
||
|
confidence intervals. The default is {opt level(95)} or as set by {help set level},
|
||
|
{opt l:evel} does not affect the confidence levels of asterisks. {p_end}
|
||
|
|
||
|
{phang}{opt ef:orm} the exponentiated form of the coefficients be reported. This corresponds to {opt or} option for
|
||
|
{help logit}, {help clogit}, and {help glogit} estimation, {opt irr} for {help poisson} estimation, {opt rrr}
|
||
|
for {help mlogit}, {opt hr} for {help cox} and {help stcox} hazard models, and
|
||
|
{opt eform} for {help xtgee}. The default form of {help stcox} is the hazard rate form; use the {opt eform} to report it. {p_end}
|
||
|
|
||
|
{phang}{opt nocon:s} specifies that the intercept (constant) be not reported.{p_end}
|
||
|
|
||
|
{phang}{opt noni} specifies that the number of groups in a panel data regression
|
||
|
not be reported (e.g. the number of groups specified by the i( ) variable in {help xtreg}).{p_end}
|
||
|
|
||
|
|
||
|
{phang}{ul:Assuming only 2 statistics reported per variable:}{p_end}
|
||
|
|
||
|
{phang}{opt tstat} t-statistics rather than standard errors are reported. The decimal places displayed are set
|
||
|
by {opt auto( )} or {opt tdec}.{p_end}
|
||
|
|
||
|
{phang}{opt pvalue} specifies that p-values (of t-statistics) rather than
|
||
|
standard errors are reported. The decimal places displayed are set by {opt auto( )} or {opt pdec}. {p_end}
|
||
|
|
||
|
{phang}{opt ci} specifies that confidence intervals of coefficients rather than
|
||
|
standard error are reported. The decimal places displayed are those set by {opt auto( )} or {opt cdec}. {p_end}
|
||
|
|
||
|
{phang}{opt be:ta} asks that normalized beta coefficients be reported rather than
|
||
|
standard errors (see the beta option of {help regress}). The decimal places
|
||
|
displayed are those set by {opt auto( )} or {opt bdec}.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Ancillary Statistics (for each regression)}
|
||
|
|
||
|
{phang}{help ereturn:{opt e(scalars)} }report {help ereturn:e-class scalars} at the bottom of the table.
|
||
|
They may be requested individually, as in {cmd:e(N ll r2)}, or for all, by specifying {cmd:e(all)}.
|
||
|
The reported e-class statistics are automatically formated by auto-digits, unless {opt ade:c}
|
||
|
has been specified for it. {p_end}
|
||
|
|
||
|
{phang}{opt adds:tat(list)} access {help ereturns:e-class}, {help return:r-class}, {help sreturn:s-class}
|
||
|
scalar statistics, or just plain numbers in new rows below the R-squared (if shown). Comma separted.
|
||
|
The user must specify both a name and a value for the statistic. Users can report significance levels
|
||
|
of test statistics as a second statistic to be shown on the line below the first statistic
|
||
|
(see example below). {p_end}
|
||
|
|
||
|
{phang}{opt addtext(list)} specifies user-added text (including
|
||
|
numbers) to be displayed in new lines below the R-squared (if shown). Unlike {opt adds:tat},
|
||
|
{opt addt:ext} will not format numbers nor try to interpret any e-class text (such as e(N) or e(title), which
|
||
|
{opt adds:tat} will translate into the number of observations or title). {p_end}
|
||
|
|
||
|
{phang}{opt nor:2} specifies that no R-squared (or adjusted R-squared) be reported.{p_end}
|
||
|
|
||
|
{phang}{opt ad:jr2} specifies that the adjusted R-squared be reported rather than the regular R-squared
|
||
|
when available.{p_end}
|
||
|
|
||
|
{phang}{opt noobs} specifies no number of observations is to be reported.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Equations and Variables}
|
||
|
|
||
|
{phang}{opt drop(varlist)} Do not report these variables. Do not include the dependent variable in this list.{p_end}
|
||
|
|
||
|
{phang}{opt keep(varlist)} Keep and report these variables. {p_end}
|
||
|
|
||
|
{phang}{opt eqdrop(eqlist)} Drop these equations from the table {p_end}
|
||
|
|
||
|
{phang}{opt eqkeep(eqlist)} Keep and report these equations. {p_end}
|
||
|
|
||
|
{phang}{opt sortvar(varlist)} Sort and order variables; non-existent variable names are ignored.{p_end}
|
||
|
|
||
|
{phang}{opt groupvar(names)} Sort and order variable; non-existent names are inserted as super-rows or row-heading.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Displays}
|
||
|
|
||
|
{phang}{opt par:enthesis( )} specifies parenthesis ( ) to be placed around any/many of these:
|
||
|
coef se tstat pval ci ci_low ci_high aster blank. Can be used with {opt br:acket( )}.{p_end}
|
||
|
|
||
|
{phang}{opt nopa:ren} specifies no parentheses be placed around standard
|
||
|
errors, t-statistics, standard errors, etc. {p_end}
|
||
|
|
||
|
{phang}{opt br:acket} specifies square brackets [ ] be used rather than
|
||
|
parentheses ( ) around standard errors, t-statistics, etc. {p_end}
|
||
|
|
||
|
{phang}{opt br:acket( )} specifies square brackets [ ] to be placed around any/many of these:
|
||
|
of these: coef se tstat pval ci ci_low ci_high aster blank. Can be used with {opt par:enthesis( )}.{p_end}
|
||
|
|
||
|
{phang}{opt alpha(numlist)} specifies the levels of significance, separated by comma
|
||
|
from the most significant to the least signficiant. Example: {opt alpha(0.001, 0.01, 0.05)}. Up to 3 are automatically
|
||
|
assigned asterisks. If more than 3 levels are defined, then the symbols must be specified with {opt sym:bol(text)}. {p_end}
|
||
|
|
||
|
{phang}{opt sym:bol(text)} specifies symbols for the levels of significance from the most significant
|
||
|
to the least significant, the default {opt sym:bol(***, **, *)}.{p_end}
|
||
|
|
||
|
{p 8 8 12}They will assigned the significance levels of 0.01, 0.05, and 0.10
|
||
|
automatically in that order. If more than 3 symbols are assigned, then the same number of levels of significance must be specified using
|
||
|
{opt alpha}.{p_end}
|
||
|
|
||
|
{phang}{opt aster:isk( )} specifies asterisks to be placed around some
|
||
|
of these: coef se tstat pval ci ci_low ci_high blank. {p_end}
|
||
|
|
||
|
{phang}{opt noas:ter} no asterisks denoting statistical significance
|
||
|
levels be reported. {p_end}
|
||
|
|
||
|
{phang}{opt 2aster} specifies 2 asterisks for 1% and 1 asterisk for 5%.
|
||
|
The default is 3 asterisks for 1%, 2 asterisks for 5%, and 1 asterisk for 10%. {p_end}
|
||
|
|
||
|
{phang}{opt 10pct} equivalent to {opt sym:bol(**, *, +)}{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Decimals and Formats}
|
||
|
|
||
|
{phang}{opt auto(integer)} the number of automatically formatted decimals, the default is {cmd:auto(3)},
|
||
|
i.e. three significant digits not counting the ones (i.e. the digit to the left of the decimal point).
|
||
|
This means 1.234 and 0.123 might be displayed, while 12.345 or 0.1234 will be trimmed.
|
||
|
|
||
|
{p 8 8 12}A probable integer is reported without decimals. A very large or small number will be displayed in
|
||
|
exponential format. Specify {opt dec( )} or {opt bd:ec( )} to disable it. {p_end}
|
||
|
|
||
|
{phang}{opt less(integer)} specifies how many less significant digits to be
|
||
|
displayed for the auxiliary (non-coefficient) statistics. The default is {cmd:less(0)}, meaning no less.{p_end}
|
||
|
|
||
|
|
||
|
{phang}{ul:fixed decimals}{p_end}
|
||
|
|
||
|
{p 8}{opt dec(#)} fixed decimals for everything, default dec(3){p_end}
|
||
|
|
||
|
{p 11} between 0 and 11, inclusive{p_end}
|
||
|
|
||
|
{p 8}{opt bd:ec( )} for coefficient{p_end}
|
||
|
{p 8}{opt sd:ec( )} for standard error{p_end}
|
||
|
{p 8}{opt td:ec( )} for t-statistics{p_end}
|
||
|
{p 8}{opt pd:ec( )} for p-value{p_end}
|
||
|
{p 8}{opt cd:ec( )} for confidence intervals{p_end}
|
||
|
{p 8}{opt rd:ec( )} for r-square{p_end}
|
||
|
{p 8}{opt ad:ec( )} for addstat( ) numerals{p_end}
|
||
|
|
||
|
|
||
|
{phang}{ul:fixed format}{p_end}
|
||
|
|
||
|
{p 8}{opt fmt(type)} format for everything, default fmt(fc){p_end}
|
||
|
|
||
|
{p 11} e - scientific notation; e.g. 1.00e+3 {p_end}
|
||
|
{p 11} f or fc - fixed format (with commas for thousands with fc){p_end}
|
||
|
{p 11} g or gc - general format (with commas for thousands with gc)
|
||
|
|
||
|
{p 8}{opt bf:mt( )} coefficient{p_end}
|
||
|
{p 8}{opt sf:mt( )} standard error{p_end}
|
||
|
{p 8}{opt tf:mt( )} t-statistics{p_end}
|
||
|
{p 8}{opt pf:mt( )} p-value{p_end}
|
||
|
{p 8}{opt cf:mt( )} confidence intervals{p_end}
|
||
|
{p 8}{opt rf:mt( )} r-square{p_end}
|
||
|
{p 8}{opt af:mt( )} addstat( ) numerals{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Marginal effects}
|
||
|
|
||
|
{phang}{opt mfx} reports marginal effects as computed by {help mfx}. It will reported marginal
|
||
|
effects instead of estiamted coefficients. {p_end}
|
||
|
|
||
|
{phang}{opt m:argin(u|c|p)} the unconditional, conditional, and probability marginal
|
||
|
effects for {help truncreg}, {net_d:marginal} from STB 52, or {net_d:dtobit} from STB 56.
|
||
|
One of u, c, or p is required after {net_d:dtobit}, corresponding to the unconditional,
|
||
|
conditional, and probability marginal effects, respectively. It is not necessary to specify
|
||
|
{opt margin} after {help dprobit}, {net_d:dlogit2}, {net_d:dprobit2}, or {net_d:dmlogit2}.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Summary Statistics}
|
||
|
|
||
|
{phang}{opt sum} summary be reported after a regression command, restricted to the estimation sample, i.e. e(sample)==1,
|
||
|
unless no regress exists or {opt raw} option specified. This is the same as {cmd:stats(mean sd)}.{p_end}
|
||
|
|
||
|
{phang}{opt raw} do not restrict the sample to e(sample) or perform casewise dropping. Currently works only with sum.
|
||
|
The number of observation reported is the maximum.{p_end}
|
||
|
|
||
|
{phang}{opt sum(log)} summary table just like the one from log file. Default is raw (no casewise dropping).
|
||
|
Use eqdrop() or eqkeep() to get what you want.{p_end}
|
||
|
|
||
|
{phang}{opt sum(detail)} detailed summary table. Default is raw (no casewise dropping).
|
||
|
Use eqdrop() or eqkeep() to get what you want.{p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Tabulations}
|
||
|
|
||
|
{phang}{opt cross:tab} n-way cross-tabulation. Varlist is required. The first
|
||
|
variable must be counting numbers, i.e. 0, 1, 2, etc., and the rest must be non-strings. See {help outreg2##s_15:example} below. {p_end}
|
||
|
|
||
|
|
||
|
{dlgtab:Rarely Used}
|
||
|
|
||
|
{phang}{opt slow(#)} A milli-second delay. Specify slow(100) or larger if you are using a laptop with a throttled
|
||
|
harddrive that runs too slowly, causing "could not be openend r(603)" error.{p_end}
|
||
|
|
||
|
|
||
|
{hline}
|
||
|
|
||
|
{marker s_0}
|
||
|
{title:Example 0. Basic game plan}
|
||
|
|
||
|
{p 4 4 6}You should specify the current directory where all the files will be stored.
|
||
|
Alternatively, you can specify the complete pathway from within {cmd:outreg2}, but you must
|
||
|
encase it with quotations marks.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata "cd c:\"}{p_end}
|
||
|
{p 4 4 6}{stata sysuse auto,clear}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight headroom trunk length turn displacement}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace cttop(full)}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight headroom}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, see}{p_end}
|
||
|
|
||
|
{p 4 4 6}You can immedicately see the changes. The variable "weight" loses some of its significance
|
||
|
in the full specification. The estimated effect of weight can be shown to be downward-biased from
|
||
|
-0.00420 to -0.00647 by omitting a number of covariates. This is an easy way to check for
|
||
|
collinearity and misspecification.{p_end}
|
||
|
|
||
|
{p 4 4 6}You can use {cmd:e( )} or {cmd:addstat( )} option to augment the standard
|
||
|
regression results with other e-class statistics (scalar only). {cmd:addstat} can handle
|
||
|
r-class and s-class results as well, if they exist. The following codes are equivalent
|
||
|
excpet in appearance.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, e(r2 ll)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, addstat(R-squared by hand, e(r2), Log Lik, e(ll))}{p_end}
|
||
|
|
||
|
{p 4 4 6}If you want to see everything available in the e-class, do it like this:{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, e(all)}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_1}
|
||
|
{title:Example 1. Prefix and bys( )}
|
||
|
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2} can be used in as a prfix.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata "outreg2 using myfile, replace ti(Car stuff): reg price mpg weight turn"}{p_end}
|
||
|
{p 4 4 6}{stata "outreg2 using myfile, see excel: reg price mpg weight turn if price > 6100"}{p_end}
|
||
|
|
||
|
{p 4 4 6}It is also byable with bys( ) prefix.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata "bys foreign: outreg2 using myfile, side replace see: reg rep78 head weight gear len [aw=mpg]"}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_2}
|
||
|
{title:Example 2. Running loops}
|
||
|
|
||
|
|
||
|
{p 4 4 6}Because this involves a loop, you must copy and paste into a do-file:
|
||
|
|
||
|
{p 4 4 6}sysuse auto,clear{p_end}
|
||
|
{p 4 4 6}cap erase myfile.txt{p_end}
|
||
|
{p 4 4 6}forval num=0/1 {{p_end}
|
||
|
{p 8 8 6}regress mpg weight headroom if foreign==`num'{p_end}
|
||
|
{p 8 8 6}outreg2 using myfile{p_end}
|
||
|
{p 4 4 6}}{p_end}
|
||
|
{p 4 4 6}seeout{p_end}
|
||
|
|
||
|
|
||
|
{marker s_3}
|
||
|
{title:Example 3. Stored estimates}
|
||
|
|
||
|
|
||
|
{p 4 4 6}You can automatically recall the stored estimates by specifying them from
|
||
|
within {cmd:outreg2}. To distinguish them from the varlist, place the estlist
|
||
|
within a pair of {cmd:[}square brackets{cmd:]}.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto,clear}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight headroom trunk length turn displacement}{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata estimates store Full}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight headroom}{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata estimates store Restricted1}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight}{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata estimates store Restricted2}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 [Full Restricted1 Restricted2] using myfile, replace see}{p_end}
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2} will take the stored estimates as wildcards (*). Try this:
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 [*] using myfile, see replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 [R*] using myfile, see replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}The varlist may be combined with the estlist. The varlist will take the
|
||
|
wildcards as well, provided they exist in the estlist.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 foreign weight [*] using myfile, see replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}If you are specifying the varlist, you must make certain the desired varlist
|
||
|
exists in all the stored estiamtes. Since not all equations may contain the
|
||
|
specified varlist, it is usually a poor idea to combine the one column option
|
||
|
with the varlist.{p_end}
|
||
|
|
||
|
|
||
|
{marker s_4}
|
||
|
{title:Example 4. Shorthand}
|
||
|
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2} will remeber the last set of options you specified until the end of
|
||
|
the day. The stored command will expire at mid-night to prevent the possible
|
||
|
loss of finished table by inadvertantly writing over a finished file. The
|
||
|
following shorthand should be tried separately.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2}{p_end}
|
||
|
{p 4 4 6}{stata outreg2, replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2, seeout}{p_end}
|
||
|
|
||
|
{p 4 4 6}The following two options are excluded from the stored command:
|
||
|
seeout and replace. These two must be specified each time you invoke {cmd:outreg2}
|
||
|
through the shorthand. To change the stored options, you must invoke the full
|
||
|
syntax with the specified using file (i.e. outreg2 using myfile, etc). The varlist
|
||
|
and the stored estimates names are not stored with the command.{p_end}
|
||
|
|
||
|
{p 4 4 6}For someone who is in a hurry, {cmd:outreg2} will take the following syntax, provided
|
||
|
the desired options have been stored by invoking them in the full syntax. The
|
||
|
varlist and/or the estlist are still allowed under this syntax. This
|
||
|
pre-command syntax is made available for the benefit of iterative users.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata "outreg2 : reg mpg foreign weight headroom"}{p_end}
|
||
|
{p 4 4 6}{stata "outreg2, replace : reg mpg foreign weight headroom"}{p_end}
|
||
|
{p 4 4 6}{stata outreg2}{p_end}
|
||
|
{p 4 4 6}{stata seeout}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_5}
|
||
|
{title:Example 5. Decimal places}
|
||
|
|
||
|
|
||
|
{p 4 4 6}By default the regression coefficients are shown with auto-digits,
|
||
|
but a user may wish to specify their own number of decimals places. We could use
|
||
|
the option dec(5) to display 5 decimal places for all statistics or bdec(5)
|
||
|
for just the coefficient, sdec(5) just for standard error, etc.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace auto(4)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, dec(5)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, bdec(5) bfmt(f) sdec(7) sfmt(e) see}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_6}
|
||
|
{title:Example 6. Sideway display}
|
||
|
|
||
|
{p 4 4 6}Medical journals often requires the displays to go sideways. Use {opt side:way} to make this
|
||
|
happen. {opt side:way} is compatible with {opt st:ats( )}.
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sideway stats(coef aster se) noparen bdec(3) replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}Note the above code is equivalent to building the table one column at a time like this:{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, stats(coef) replace noparen bdec(3)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, stats(aster) noparen bdec(3)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, stats(se) noparen bdec(3)}{p_end}
|
||
|
|
||
|
{p 4 4 6}Some journals often prefer t-statistics to standard errors
|
||
|
and don't use asterisks to denote statistical significance. Some people use brackets. The
|
||
|
title( ) option requires quotation marks when it contains a comma. Note that {opt bdec} decimal
|
||
|
option apply to both the coefficients and the standard errors.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata regress mpg foreign weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, tstat bracket noaster title("No standard errors!")}{p_end}
|
||
|
{p 4 4 6}{stata seeout}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_7}
|
||
|
{title:Example 7. Summary tables}
|
||
|
|
||
|
{p 4 4 6}Use {opt sum} to place summary statistics into a table. The sample mean and the standard
|
||
|
deviation for the sample used in the earlier regression will be automatically displayed.
|
||
|
|
||
|
{p 4 4 6}* After estimation{p_end}
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata reg mpg price rep weight length}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sum replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, see}{p_end}
|
||
|
|
||
|
{p 4 4 6}* Regular summary table{p_end}
|
||
|
{p 4 4 6}* note: version 11 and above requires clear* to prevent mismatch between e(b) and e(sample){p_end}
|
||
|
{p 4 4 6}{stata clear*}{p_end}
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sum(log) replace eqdrop(N mean) see}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sum(detail) replace eqkeep(N max min) see}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sum(detail) replace see}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_8}
|
||
|
{title:Example 8. Drop/keep/order variables}
|
||
|
|
||
|
|
||
|
{p 4 4 6}Specifying a varlist can be convenient to limit the output
|
||
|
table to only the essential coefficients. For example, we may want to control for
|
||
|
the influence of dummy variables, but not report their estimated coefficients.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata tab rep78, gen(repair)}{p_end}
|
||
|
{p 4 4 6}{stata regress mpg foreign weight repair1-repair4}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 weight foreign using myfile, drop(repair*)}{p_end}
|
||
|
|
||
|
{p 4 4 6}Alternatively, {opt keep( )} and {opt drop( )} can be used to control the displayed
|
||
|
variables. Use {opt nocons} to drop constants.
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, drop(repair*) replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, keep(mpg foreign)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, nocons}{p_end}
|
||
|
{p 4 4 6}{stata seeout}{p_end}
|
||
|
|
||
|
{p 4 4 6}There are several ways to order variables in the output. The first is
|
||
|
to order them when running regression. The second way is to specify varlist
|
||
|
from within {cmd:outreg2}. Or you might try {opt sortvar( )} or {opt groupvar( )}.{p_end}
|
||
|
|
||
|
{p 4 4 6}* single equation{p_end}
|
||
|
{p 4 4 6}{stata reg mpg rep78 head trunk weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace sortvar(trunk turn)}{p_end}
|
||
|
{p 4 4 6}{stata reg mpg rep78 head weight turn disp gear}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sortvar(trunk turn) see}{p_end}
|
||
|
|
||
|
{p 4 4 6}* multiple equations{p_end}
|
||
|
{p 4 4 6}{stata reg3 (mpg rep78 head trunk weight) (head trunk weight rep78 gear)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace long}{p_end}
|
||
|
{p 4 4 6}{stata reg3 (mpg rep78 head weight turn disp ) (mpg rep78 head trunk weight gear)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, sortvar(trunk turn) see long}{p_end}
|
||
|
|
||
|
{p 4 4 6}* groupvar( ) will create super-rows{p_end}
|
||
|
{p 4 4 6}{stata reg mpg rep78 head trunk weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace}{p_end}
|
||
|
{p 4 4 6}{stata reg mpg rep78 head weight turn disp gear}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, groupvar(Group1 trunk turn head weight Group2) see}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_9}
|
||
|
{title:Example 9. Adding r( ) e( ) scalars}
|
||
|
|
||
|
|
||
|
{p 4 4 6}Additional statistics may be added with {opt adds:tat( )} or {opt addt:ext( )}. Values stored in
|
||
|
macros r(), e(), or s() can be included directly. You can see what values are available by typing
|
||
|
{cmd:ereturn list} or {cmd:return list}.{p_end}
|
||
|
|
||
|
{p 4 4 6}To test the equality of two of the estimated coefficients and report the results in the table, note
|
||
|
that {cmd:test} will sometimes return chi-squared, then you would instead use {opt addstat(chi-square test, r(chi2))}:
|
||
|
{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata reg mpg foreign weight length}{p_end}
|
||
|
{p 4 4 6}{stata test foreign length}{p_end}
|
||
|
{p 4 4 6}{stata `"outreg2 using myfile, adds("F test: Type=Length=0", r(F), Prob > F, `r(p)') replace"'}{p_end}
|
||
|
{p 4 4 6}{stata seeout} {p_end}
|
||
|
|
||
|
{p 4 4 6}To add results of lincom postestimation command to a table:{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata reg price mpg rep78 head}{p_end}
|
||
|
{p 4 4 6}{stata lincom mpg + rep}{p_end}
|
||
|
{p 4 4 6}{stata local tstat=r(estimate)/r(se)}{p_end}
|
||
|
{p 4 4 6}{stata local pval = tprob(r(df), abs(`tstat'))}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using "myfile", adds(joint, r(estimate), t-stat, `tstat', p-val,`pval') replace see}{p_end}
|
||
|
|
||
|
{p 4 4 6}In some cases it is better to save the value of a previously calculated
|
||
|
statistic in a local macro and then put the macro value into {opt adds:tat( )}. Save the first F
|
||
|
statistic in a local macro:{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata regress mpg rep78 headroom}{p_end}
|
||
|
{p 4 4 6}{stata test rep78}{p_end}
|
||
|
{p 4 4 6}{stata local F1 = r(F)}{p_end}
|
||
|
{p 4 4 6}{stata test headroom}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using 2test, addstat(Test1 F, `F1', Test2 F, `r(F)')}{p_end}
|
||
|
|
||
|
{p 4 4 6}It it is missing, {cmd:outreg2} will automatically calculate e(p), which is presumably
|
||
|
the F-test or chi-square-test of significance of a regression.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, addstat(F test, e(p))}{p_end}
|
||
|
|
||
|
{p 4 4 6}Another example would be to report a pseudo R-squared
|
||
|
after a logit estimation, which {cmd:outreg2} does not otherwise report.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata logit foreign price trunk weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, addstat(Pseudo R-squared, `e(r2_p)')}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_10}
|
||
|
{title:Example 10. Odds ratios and exponentials}
|
||
|
|
||
|
|
||
|
{p 4 4 6}Odds ratios are exponential transformations of coefficients. As noted above,
|
||
|
there is no way of knowing after an estimation command if the
|
||
|
user chose to report the exponentiated form of coefficients. The user must
|
||
|
choose the {opt eform} option in {cmd:outreg2} to get the same form of the coefficients
|
||
|
displayed by the estimation into the {cmd:outreg2} table.{p_end}
|
||
|
|
||
|
{p 4 4 6}For duration models, the exponential form is known as the hazard ratio. For
|
||
|
other models it is known as odds ratio, relative risk ratio, or incidence rate
|
||
|
ratio.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto,clear}{p_end}
|
||
|
{p 4 4 6}{stata logit foreign price mpg rep78, or}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using eform_example, replace cti(raw)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using eform_example, eform cti(odds ratio) see}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_11}
|
||
|
{title:Example 11. Marginal Effects}
|
||
|
|
||
|
{p 4 4 6}{opt mfx} option can be used to report marginal effects after {help mfx} command
|
||
|
has been applied.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata logit foreign mpg rep78 head}{p_end}
|
||
|
{p 4 4 6}{stata mfx compute}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, mfx ctitle(mfx) see}{p_end}
|
||
|
|
||
|
{p 4 4 6}For multiple outcomes, you may want to use {cmd:mfx2} by Ricahrd Williams or
|
||
|
{search margeff} by Tamas Bartus. They are both available from {help ssc}. {p_end}
|
||
|
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata mlogit rep turn mpg price}{p_end}
|
||
|
{p 4 4 6}{stata margeff, at(mean) replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, cttop(margeff) see replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}{cmd:mfx2} runs a little slower:{p_end}
|
||
|
{p 4 4 6}{stata mlogit rep turn mpg price}{p_end}
|
||
|
{p 4 4 6}{stata mfx2, replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, long cttop(mfx2) see replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}The marginal effects reported by {search dprobit}, {net_d:dlogit2}, {net_d:dprobit2},
|
||
|
and {search dmlogit2} are automatically reported by {cmd:outreg2}.{p_end}
|
||
|
|
||
|
{p 4 4 6}Because {net_d:truncreg}, {net_d:marginal}, and {net_d:dtobit} report
|
||
|
both regression coefficients and marginal effects, the user must specify the
|
||
|
{opt margin} option for {cmd:outreg2} report the marginal effects.{p_end}
|
||
|
|
||
|
{p 4 4 6}{search dtobit}, on the other hand, calculates three different marginal effects.
|
||
|
The user must specify which marginal effect, the unconditional, conditional,
|
||
|
or the probability uncensored, to be reported. Note that "version 6" must be set for
|
||
|
{cmd:dtobit} to work.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata tobit mpg trunk weight, ll(17)}{p_end}
|
||
|
{p 4 4 6}{stata `"version 6: dtobit"'}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, margin(u) ctitle(Unconditional) nor2 replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, margin(c) ctitle(Conditional) nor2}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, margin(p) ctitle(Probability) nor2 see}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_12}
|
||
|
{title:Example 12. Word or Excel files}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
Use {opt word} or {opt excel} for automatic generation of Word/Excel files:
|
||
|
|
||
|
{p 4 4 6}{stata reg price mpg rep78 headroom trunk weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, word excel replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
Follow these directions for manual conversions from .txt files:
|
||
|
|
||
|
{p 4 4 6}
|
||
|
In {cmd:MS Word}, open or insert the file created by {cmd:outreg2}. Select the estimation text that
|
||
|
is in columns (not the notes at the bottom of the table or the title at the top, if any), and choose
|
||
|
Table, Convert Text to Table.
|
||
|
|
||
|
{p 4 4 6}To shift the table within {cmd:MS Word}, highlight the entire table, choose Table
|
||
|
Properties (go the top menu, drag down on the Table option), and then click the alignment as
|
||
|
Left instead of Center.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
In {cmd:Excel}, open the file created by {cmd:outreg2} and follow the default choices
|
||
|
in the Text Import Wizard (if you do not see the file, choose All Files as the File Type).
|
||
|
Prevent the conversion of the parenthesis into a negative number (an accounting convention)
|
||
|
by doing the following: 1. import it as "Delimited", 2. choose Tab as the Delimiters, and
|
||
|
3. Choose "Text" as Column data format after Highlighting all the columns by shift-down, right-clicking.
|
||
|
|
||
|
{p 4 4 6}If you wish to export the
|
||
|
.xml table to a word processor, you should separately copy the table and the notes
|
||
|
at the bottom of the table (prevents the notes from taking up too much space). You
|
||
|
can avoid this problem by opening the .txt file manually from inside {cmd:MS Excel},
|
||
|
as detailed earlier, or copy and paste the notes into another cells in
|
||
|
{cmd:MS Excel}, which will cause them to be displayed properly.
|
||
|
|
||
|
{p 4 4 6}To get rid of "green tabs" in Excel: From inisde Excel, Tools > Options > Error Checking.
|
||
|
When you get there, uncheck "Number stored as text". No more green triangles.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
You can also use {cmd:{browse "http://www.stata.com/support/faqs/data/convert2.html":Stat/Transfer}}
|
||
|
if you have one. Choose ASCII-Delimited as the input file and choose {cmd:Excel}
|
||
|
as the output file. You will need to adjust the column widths from inside
|
||
|
{cmd:Excel}.
|
||
|
|
||
|
|
||
|
{marker s_13}
|
||
|
{title:Example 13. TeX files}
|
||
|
|
||
|
|
||
|
{p 4 4 6}
|
||
|
{cmd:LaTeX} compatible table can be created with {opt tex} option. With the use
|
||
|
of free conversion software, such as MiKTeX, you can create Adobe PDF files of
|
||
|
the finished tables directly within Stata by invoking a shell command.
|
||
|
|
||
|
{p 4 4 6}{stata regress mpg foreign weight}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, tex replace}{p_end}
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2's} TeX tables are fully formatted, unlike the ASCII tables. This
|
||
|
requires free TeX to Adobe PDF conversion software, such as the MiKTeX
|
||
|
(www.miktek.org) for Windows or teTeX (www.tug.org/teTeX/) for Unix/Linux. The
|
||
|
whole process is automated in Stata with a shell command:{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata !texify -p -c -b --run-viewer myfile.tex} {using MiKTeX on Windows){p_end}
|
||
|
{p 4 4 6}{stata !pdflatex myfile} (using teTeX on Linux){p_end}
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2} cannot append TeX format tables to one another, so regressions must be
|
||
|
appended in ASCII form until the last regression, which is appended with the
|
||
|
{opt tex} option.{_end}
|
||
|
|
||
|
{p 4 4 6}The base font point size of tex in a TeX table can be specified with the {opt tex()}
|
||
|
parameter. TeX only allows font sizes of 10 and 11 points besides the default
|
||
|
of 12 point. The {opt texfrag} option creates a TeX fragment for inclusion in a larger
|
||
|
TeX document. For example, a TeX fragment table from the first regression above could be created with
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, tex(frag)}{p_end}
|
||
|
|
||
|
{p 4 4 6}and then be included in the following TeX document with the \input{myfile}
|
||
|
command:{p_end}
|
||
|
|
||
|
\documentclass[10pt]{article}
|
||
|
\begin{document}
|
||
|
... text before inclusion of table myfile.tex ...
|
||
|
\input{myfile}
|
||
|
... text after inclusion of table myfile.tex ...
|
||
|
\end{document}
|
||
|
|
||
|
|
||
|
{p 4 4 6}Technical Note: Many of the non-alphanumeric characters have special meaning
|
||
|
in TeX, namely _, %, #, $, &, ~, ^^, \, {, }. If you want these characters to
|
||
|
be printed in TeX like any other character, include a \ in front of the
|
||
|
character. {cmd:outreg2} automatically does this for the first two, _ and %,
|
||
|
because _ often turns up in Stata variable names and % is common in variable
|
||
|
labels and explanatory notes. You can include the other characters in titles,
|
||
|
variable labels, or notes if you preceed them with with a \ in the Stata text.
|
||
|
The exception is \ itself; \ must be replaced with $\backslash$ to render
|
||
|
properly in TeX.{p_end}
|
||
|
|
||
|
{p 4 4 6}In addition, in TeX the characters <, >, and | will only appear as themselves
|
||
|
in math mode, so they must be written as $<$, $>$, and $|$.{p_end}
|
||
|
|
||
|
{p 4 4 6}TeX codes can be inserted into {cmd:outeg2} titles, variable labels, and added
|
||
|
notes. This requires understanding TeX formatting codes. The example below
|
||
|
creates a Greek letter chi with a squared exponent for a chi-squared test
|
||
|
statistic.{p_end}
|
||
|
|
||
|
{phang2}{stata outreg2 using myfile0, addstat($\chi^2$, 22.1) tex}{p_end}
|
||
|
|
||
|
{p 4 4 6}I said above that {cmd:outreg2} automatically converted _ to \_. An exception is
|
||
|
when it finds two $'s in the text, in which case it assumes the _ is a
|
||
|
subscript designator in a TeX inline equation. That means that if you want to
|
||
|
add text that includes an inline equation, but you really want the _ to appear
|
||
|
as such in the TeX table, you must replace it with a \_.{p_end}
|
||
|
|
||
|
{p 4 4 6}Be careful when using $. When $ is immediately followed by a letter, Stata
|
||
|
will interpret this as a global macro. To get Stata to output a literal $,
|
||
|
precede it with "\": \$. If you want, for example, a properly TeX typeset
|
||
|
R-squared to survive in {cmd:outreg2}, rather than "$R^2$" you must use "\$R^2$".
|
||
|
$R would be evaluated by {cmd:outreg2} as the value of global macro R, which is
|
||
|
probably empty.{p_end}
|
||
|
|
||
|
{p 4 4 6}Putting a literal "$" in TeX output can be confusing: to get "$US" in the TeX
|
||
|
output, for example, one needs "\$US" in the TeX input file, which requires
|
||
|
"\\\$US" in Stata text, because Stata resolves "\\" into "\" and "\$" into "$".{p_end}
|
||
|
|
||
|
{p 4 4 6}A final quirk: you cannot use the results of the Stata macro $S_FN in {cmd:outreg2}
|
||
|
text for a TeX table if you use Microsoft Windows. $S_FN returns the path name
|
||
|
for the current data file which in Windows includes \ characters which will
|
||
|
prevent the TeX table from rendering properly.{p_end}
|
||
|
|
||
|
|
||
|
{marker s_14}
|
||
|
{title:Example 14. Adding column titles or notes}
|
||
|
|
||
|
|
||
|
{p 4 4 6}You can add a column title "Base case (mpg)" to distinguish this regression from a
|
||
|
second regression. No quotation marks are required around the column title because
|
||
|
it does not contain commas. Use {opt cttop( )} to add additional column title to the default column titles.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace ctitle(Base case (mpg))}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, cttop(On top)}{p_end}
|
||
|
|
||
|
{p 4 4 6}You can add explanatory note at the bottom of a column using the {opt addn:ote} option.
|
||
|
Note that since the text in {opt addn:ote} does not contain parentheses or commas
|
||
|
it does not need quotation marks.{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata outreg2 using myfile, addnote(Dummy variables not shown)} {p_end}
|
||
|
|
||
|
{p 4 4 6}{opt addnote} for inserting a blank line, followed by the time the program was run (from the
|
||
|
built-in Stata functions $S_TIME and $S_DATE), and the dataset used by the
|
||
|
estimation (from the Stata function $S_FN).{p_end}
|
||
|
|
||
|
{p 4 4 6}{stata regress mpg foreign weight length}{p_end}
|
||
|
{p 4 4 6}{stata `"outreg2 using myfile, addn("", "Time $S_TIME, $S_DATE", Data from $S_FN) replace"'} {p_end}
|
||
|
|
||
|
|
||
|
{marker s_15}
|
||
|
{title:Example 15. n-way cross-tabulation}
|
||
|
|
||
|
{p 4 4 6}n-way tabulation likes of which are also produced by tab3way or table. It will take about a minute to run.{p_end}
|
||
|
|
||
|
{p 4 4 6}* Prepare data{p_end}
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata egen mileage=cut(mpg), group(10)}{p_end}
|
||
|
{p 4 4 6}{stata egen paid=cut(price), group(3)}{p_end}
|
||
|
{p 4 4 6}{stata egen heavy=cut(weight), group(3)}{p_end}
|
||
|
|
||
|
{p 4 4 6}* 3-way cross-tabulation{p_end}
|
||
|
{p 4 4 6}{stata outreg2 mileage paid heavy using myfile, see replace cross}{p_end}
|
||
|
|
||
|
{p 4 4 6}* 3-way cross-tabulation sideway{p_end}
|
||
|
{p 4 4 6}{stata outreg2 mileage paid heavy using myfile, see replace cross side}{p_end}
|
||
|
|
||
|
{p 4 4 6}* 5-way cross-tabulation without percentage{p_end}
|
||
|
{p 4 4 6}{stata outreg2 mileage paid foreign rep78 heavy using myfile, see replace cross stats(coef)}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_16}
|
||
|
{title:Example 16. Group summary table}
|
||
|
|
||
|
{p 4 8 8}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 8 8}{stata gen white=cond(uniform()>.5,1,0)}{p_end}
|
||
|
{p 4 8 8}{stata gen black=cond(white==1,0,1)}{p_end}
|
||
|
{p 4 8 8}{stata gen male=cond(uniform()>.5,1,0)}{p_end}
|
||
|
{p 4 8 8}{stata gen female=cond(male==1,0,1)}{p_end}
|
||
|
|
||
|
{p 4 8 8}{stata outreg2 using myfile if white==1 & male==1, sum(log) eqkeep(mean N) cttop(white, male) drop(white male female) excel replace}{p_end}
|
||
|
{p 4 8 8}{stata outreg2 using myfile if white==1 & female==1, sum(log) eqkeep(mean N) cttop( , female) drop(white male female) excel}{p_end}
|
||
|
{p 4 8 8}{stata outreg2 using myfile if white==1, sum(log) eqkeep(mean N) cttop( , total) drop(white male female) excel}{p_end}
|
||
|
{p 4 8 8}{stata outreg2 using myfile if black==1 & male==1, sum(log) eqkeep(mean N) cttop(black, male) drop(white male female) excel}{p_end}
|
||
|
{p 4 8 8}{stata outreg2 using myfile if black==1 & female==1, sum(log) eqkeep(mean N) cttop( , female) drop(white male female) excel}{p_end}
|
||
|
{p 4 8 8}{stata outreg2 using myfile if black==1, sum(log) eqkeep(mean N) cttop( , total) drop(white male female) excel}{p_end}
|
||
|
|
||
|
|
||
|
{p 4 8 8}* or just do it as a -by:- command{p_end}
|
||
|
{p 4 8 8}{stata bys male black: outreg2 using myfile, sum(log) eqkeep(mean N) drop(white female male black) excel replace}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_17}
|
||
|
{title:Example 17. Fixed effects or legends}
|
||
|
|
||
|
{p 4 4 6}Two-way fixed-effects estimation with dummy indicators:{p_end}
|
||
|
|
||
|
{p 4 4 6}* set up data{p_end}
|
||
|
{p 4 4 6}{stata sysuse auto, clear}{p_end}
|
||
|
{p 4 4 6}{stata ren rep78 state}{p_end}
|
||
|
{p 4 4 6}{stata ren turn id}{p_end}
|
||
|
{p 4 4 6}{stata keep id price mpg weight state}{p_end}
|
||
|
{p 4 4 6}{stata tab state, gen(ST)}{p_end}
|
||
|
|
||
|
{p 4 4 6}* regress and report{p_end}
|
||
|
{p 4 4 6}{stata xtreg price mpg weight ST*, fe i(id)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, replace drop(ST*) addtext(State FE, YES, Year FE, YES)}{p_end}
|
||
|
{p 4 4 6}{stata xtreg price mpg weight ST*, fe i(id)}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, drop(ST*) addtext(State FE, NO, Year FE, YES)}{p_end}
|
||
|
{p 4 4 6}{stata reg price mpg weight ST*}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, drop(ST*) addtext(State FE, NO, Year FE, NO)}{p_end}
|
||
|
|
||
|
{p 4 4 6}* legend{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, st(str(Coef) str(Stn Err) str(Spearman)) noparen ct(Legend) replace}{p_end}
|
||
|
{p 4 4 6}{stata outreg2 using myfile, st(coef se spearman blank)}{p_end}
|
||
|
|
||
|
|
||
|
{marker s_18}
|
||
|
{title:Example 18. Insert r-class cmd( ) outputs}
|
||
|
|
||
|
{p 4 4 6}You can insert output from r-class command in the table body through cmd( : ) sub-option. Indep and dependent
|
||
|
variables will be fed to them.{p_end}
|
||
|
|
||
|
{p 4 4 6}* outputs Kendall's tau-a and tau-b{p_end}
|
||
|
{p 4 4 6}sysuse auto, clear{p_end}
|
||
|
{p 4 4 6}reg rep78 headroom length turn gear_ratio{p_end}
|
||
|
{p 4 12 8}outreg2 using myfile, replace stats(corr, spearman, cmd(r(tau_a): ktau), /*{p_end}
|
||
|
{p 12 12 8}*/cmd(r(tau_b): ktau)){p_end}
|
||
|
|
||
|
{p 4 4 6}* double-check{p_end}
|
||
|
{p 4 4 6}ktau rep78 headroom{p_end}
|
||
|
{p 4 4 6}ret list{p_end}
|
||
|
|
||
|
|
||
|
{p 4 4 6}{ul:Write and insert your own r-class output}
|
||
|
|
||
|
{p 4 4 6}You can write your own r-class program and insert their outputs. A scalar should be returned
|
||
|
on two inputs: independent variable and dependent variable. It needs to accept [if] syntax.
|
||
|
c_local programs will work, too, but there might be a conflict.{p_end}
|
||
|
|
||
|
{p 4 4 6}* r-class program that calculates coefficient of variation{p_end}
|
||
|
{p 4 4 6}cap prog drop coefvar{p_end}
|
||
|
{p 4 4 6}prog define coefvar, rclass{p_end}
|
||
|
{p 8 8 8}syntax varlist(max=2) [if]{p_end}
|
||
|
{p 8 8 8}gettoken dep indep : varlist{p_end}
|
||
|
{p 8 8 8}qui sum `indep' `if'{p_end}
|
||
|
{p 8 8 8}local variation=`r(sd)'/`r(mean)'*100{p_end}
|
||
|
{p 8 8 8}ret scalar variation=`variation'{p_end}
|
||
|
{p 4 4 6}end{p_end}
|
||
|
|
||
|
{p 4 4 6}* test your r-class program{p_end}
|
||
|
{p 4 4 6}sysuse auto, clear{p_end}
|
||
|
{p 4 4 6}reg rep78 headroom length turn gear_ratio{p_end}
|
||
|
{p 4 4 6}coefvar rep78 headroom if e(sample){p_end}
|
||
|
{p 4 4 6}ret list{p_end}
|
||
|
|
||
|
{p 4 4 6}* run them{p_end}
|
||
|
{p 4 4 6}sysuse auto, clear{p_end}
|
||
|
{p 4 4 6}reg rep78 headroom length turn gear_ratio{p_end}
|
||
|
{p 4 4 6}outreg2 using myfile, replace stats(coef, se, sd, cmd(r(variation): coefvar)){p_end}
|
||
|
|
||
|
|
||
|
{p 4 4 6}{ul:A c_local program with its own option}{p_end}
|
||
|
|
||
|
{p 4 4 6}* calculates coefficient of variation{p_end}
|
||
|
{p 4 4 6}cap prog drop coefvar2{p_end}
|
||
|
{p 4 4 6}prog define coefvar2{p_end}
|
||
|
{p 8 8 8}syntax varlist(max=2) [if], [proportion]{p_end}
|
||
|
{p 8 8 8}gettoken dep indep : varlist{p_end}
|
||
|
{p 8 8 8}qui sum `indep' `if'{p_end}
|
||
|
{p 8 8 8}local hundred 100{p_end}
|
||
|
{p 8 8 8}if "`proportion'"=="proportion" {{p_end}
|
||
|
{p 12 12 8}local hundred 1{p_end}
|
||
|
{p 8 8 8}}{p_end}
|
||
|
{p 8 8 8}local variation=`r(sd)'/`r(mean)'*`hundred'{p_end}
|
||
|
{p 8 8 8} c_local variation=`variation'{p_end}
|
||
|
{p 4 4 6}end{p_end}
|
||
|
|
||
|
{p 4 4 6}* run them{p_end}
|
||
|
{p 4 4 6}sysuse auto, clear{p_end}
|
||
|
{p 4 4 6}reg rep78 headroom length turn gear_ratio{p_end}
|
||
|
{p 4 4 6}outreg2 using myfile, stats(coef, se, sd, cmd(variation: coefvar2, proportion)){p_end}
|
||
|
|
||
|
|
||
|
{p 4 4 6}{ul:Send one to the e-mail address below}
|
||
|
|
||
|
{p 4 4 6}If you can send me a program like these, and I agree it is useful, then it can made into
|
||
|
a sub-option out of it for inclusion the future versions of -outreg2-. Please note that it should be
|
||
|
something of interest to other people.{p_end}
|
||
|
|
||
|
|
||
|
{hline}
|
||
|
|
||
|
{marker s_Differences}
|
||
|
{title:Different versions of {cmdab:outreg} and {cmdab:outreg2}}
|
||
|
|
||
|
{p 4 4 6}{cmd:outreg2} will work under different versions of Stata:{p_end}
|
||
|
|
||
|
{p 4 4 6}Stata 11.0: {cmd:seeout} will require an additional keyboard hit before moving on{p_end}
|
||
|
{p 4 4 6}Stata 8.2: full functionality{p_end}
|
||
|
{p 4 4 6}Stata 8.0: reported stored estimates will be left behind when they are specified{p_end}
|
||
|
{p 4 4 6}Stata 7.0: no stored estimated{p_end}
|
||
|
{p 15 15 15}no colon character ":" in your file path; use -cd- instead{p_end}
|
||
|
{p 15 15 15}Shorthand syntax for outreg2 or seeout will not work in versions earlier than 8.0.{p_end}
|
||
|
{p 15 15 15}tfmt(.), rfmt(.), pft(.), afmt(.) do not work{p_end}
|
||
|
{p 15 15 15}cmd( ) and str( ) do not work.{p_end}
|
||
|
{p 15 15 15}Other limitations may exit exist; best not to try anything complicated{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
Compared to the original {cmd:outreg}, {cmd:outreg2} implements the following as
|
||
|
the default: {opt append}, {opt 3aster}, {opt coefastr}, {opt se}, and {opt nolabel}.
|
||
|
{opt 2aster} and {opt tstat} provide the access to the old default options. {opt si:gsymb}
|
||
|
is replaced with {opt sym:bol}. {opt x:stats} is not supported.{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
The auxiliary statistics (standard error, etc) are no longer reported in
|
||
|
absolute values. The levels of significance are strictly less than the values
|
||
|
(used to be less than or equal to). bdec and bfmt no longer take multiple inputs.
|
||
|
|
||
|
{p 4 4 6}
|
||
|
The embedded spaces in the folder names are now accepted. {opt ti:tle(list)} can be added anytime.
|
||
|
The .out extension is phased out in favor of .txt extension. A new file will be created if it did not exist.
|
||
|
The past restrictions on the number and the size of variable names have been
|
||
|
generally expanded to the system limit.{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
The newly available features are the access to {opt label},
|
||
|
{help ereturn:{opt e(ereturn scalars)}}, automatically formatted digits
|
||
|
by {opt auto(integer)} and {opt less(integer)}, {opt alpha(numlist)} provides
|
||
|
user-defined test of hypothesis, {opt seeo:ut} calls up the pop up table in
|
||
|
the data browser view, the choice of equation names as wide or {opt long},
|
||
|
the converted tables in {opt word}, {opt excel}, and {opt tex} with the
|
||
|
{cmd:shellout} commands for them placed on the screen.{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
The {cmd:[}{help estimates:{it:estlist}}{cmd:]}, which is a
|
||
|
list of stored estimates, is accepted with or without wildcard abbreviations.
|
||
|
The shorthand syntax with a limited option can now be implemented
|
||
|
as an independent command following a regression command, or as a pre-command
|
||
|
preceeding it.{p_end}
|
||
|
|
||
|
{p 4 4 6}
|
||
|
The {cmd:seeout} shell is also placed on the screen. The
|
||
|
{cmd:seeout} command will work only after {cmd:outreg2}. A majority of options
|
||
|
should work with 8.2. The shell commands were designed with a Windows XP/NT.
|
||
|
They will not work on non-Windows platforms.{p_end}
|
||
|
|
||
|
|
||
|
{title:Author}
|
||
|
|
||
|
{p 4 4 6}Roy Wada{p_end}
|
||
|
{p 4 4 6}roywada@hotmail.com{p_end}
|
||
|
|
||
|
{p 4 4 6}based on the earlier works by{p_end}
|
||
|
{p 4 4 6}John Luke Gallup{p_end}
|
||
|
{p 4 4 6}john_gallup@alum.swarthmore.edu{p_end}
|
||
|
|
||
|
{p 4 4 6}Thanks to Kit Baum for advice and providing access to John's later works.
|
||
|
I also thank those who have reported errors, making it possible to fix them in timely
|
||
|
fashion.{p_end}
|
||
|
|
||
|
|
||
|
{title:Also see}
|
||
|
|
||
|
{p 3}STB: sg97 (STB-46, STB-49, STB-58){p_end}
|
||
|
{p}Manual: {bf:[U] Estimation and post-estimation commands}{p_end}
|
||
|
{p 9}{bf:[U] Overview of model estimation}{p_end}
|
||
|
{p 9}{bf:[R] Estimation commands}{p_end}
|
||
|
|
||
|
{p }Online: {help est}, {help postfile}, {help outfile}, {help outsheet}, {help save},
|
||
|
{search modltbl}, {search desrep} {p_end}
|
||
|
|
||
|
{s6hlp}
|
||
|
{smcl}
|
||
|
|
||
|
|
||
|
|
||
|
|