Stata连享会 主页 || 视频 || 推文 || 知乎 || Bilibili 站
温馨提示: 定期 清理浏览器缓存,可以获得最佳浏览体验。
New!
lianxh
命令发布了:
随时搜索推文、Stata 资源。安装:
. ssc install lianxh
详情参见帮助文件 (有惊喜):
. help lianxh
连享会新命令:cnssc
,ihelp
,rdbalance
,gitee
,installpkg
⛳ Stata 系列推文:
作者: 吴水亭 (广西财经大学)
目录
Stata 结果输出系列推文:
君生我未生,我生君已老;
恨不生同时,日日与君好。
我离君天涯,君隔我海角;
化蝶去寻花,夜夜栖芳草。
每次折腾论文表格时,总是痛恨自己手慢,更怨骂万恶的 Word 排版。
然而,偶拾
esttab
、outreg2
,尤其是最近发布的sum2docx
,reg2docx
,不禁想起上面这首小诗。于是,庸俗地感慨:凄凄三键毁,但因识君晚!Ctrl • C • V
描述性统计、相关系数矩阵、组间均值差异检验和实证结果 是实证论文中最常见、同时也是最重要的四张基本表格。
Stata 官方命令 est table
仅能输出回归结果表格,效果差强人意,与多数期刊的格式要求相去甚远。
外部命令则主要使用 logout
命令输出描述性统计、相关系数矩阵,用 ttable2
或 ttable3
输出组间均值检验表格,esttab
或 outreg2
输出回归结果。对于 Stata 15 以前的用户而言,这些外部命令已经基本上可以满足我们的需求。缺点是,每张表格需要单独存放于一个 Word 或 Excel 文档,事后尚需手动合并之。
在 Stata 命令窗口中输入 ssc hot, n(25)
,你会发现下载量最大的前 25 个命令中,有 7 个都是用于结果输出的。
若想锦上添花,我们可以使用今天介绍的四个命令,将论文中的所有表格自动汇总到一个 Word 文档中,大幅提高表格处理效率。
那么,描述性统计、相关系数矩阵、组建均值差异检验和回归结果四张常用表格如何快速输出?我们可以使用四个热门的外部命令: sum2docx, corr2docx, t2docx 和 reg2docx:
help sum2docx
// 将描述性统计量表直接输出到一个 docx 文件中;help corr2docx
// 将相关系数矩阵直接输入到一个 docx 文件中;help t2docx
// 将分组均值 t 检验结果导出到一个 docx 文件中;help reg2docx
// 将回归结果导出至 docx 文件中,用法类似于 esttab。特别注意: 这些命令在不断更新,选项也会有变化,因此,需要使用
ssc install cmdName, replace
命令安装最新版本,进而输入help cmdName
查看其帮助文件。
只需在 Stata 命令窗口执行 ssc install **2docx, replace
即可。
附加 replace
可以保证下载最新版并自动覆盖旧文件。
以安装 sum2docx
为例,其命令为:
. ssc install sum2docx, replace
sum2docx varlist [if] [in] using filename, [options]
其中, varlist 指数值型变量列表, filename 指的是输出的文件名,该命令的 options 非常丰富,可以根据需要选择。
sysuse auto,clear
sum2docx price-foreign using ///
1.docx, append obs ///
mean(%9.2f) sd min(%9.0g) ///
median(%9.0g) max(%9.0g) ///
title("表 1: 描述性统计")
shellout 1.docx
结果如图:
corr2docx varlist [if] [in] using filename, [options]
其中,varlist
指数值型变量列表,filename
指的是输出的文件名。
sysuse auto,clear
corr2docx price-foreign using ///
2.docx, star(* 0.05) ///
fmt(%4.2f) ///
title("表 2:相关系数矩阵")
shellout 2.docx
想指定显示特定的显著性水平并加标记,想设置小数点位数可以加上 fmt
选项。
结果如图:
corr2docx varlist [if] [in] using filename [, options]
其中, varlist 指数值型变量列表, filename 指的是输出的文件名
sysuse auto, clear
t2docx price weight length mpg ///
using 3.docx,replace ///
by(foreign) ///
title("表 3: t 检验")
shellout 3.docx
当然也可以改变小数点位数,加星星啥的,和上面一样一样的。
结果如图:
如果我们想把几个回归结果何在一张表里,该如何处理?
reg2docx
命令可以将回归结果保存到 .docx 文件中,用法类似于 esttab
。先逐项回归后再汇总至一个文件中。
*-调入数据
sysuse "auto.dta", clear
*-比如先做两个线性回归
reg price mpg weight length
est store m1
reg price mpg weight length foreign
est store m2
*-然后再做一个 Probit 回归
probit foreign price weight length
est store m3
*-输出结果至 Word 文档
reg2docx m1 m2 m3 using result.docx, ///
ar2(%9.2f) b(%9.3f) t(%7.2f) r2(%9.3f) ///
title("表4: 回归结果") replace
*-查看 Word 文档
shellout result.docx
结果如图:
putdocx
命令生成一个空白 Word 文档 - [My_Table.docx],进而使用putdocx text
等命令设定文档属性;sum2docx
生成「表 1」
, 并使用sum2docx
命令的append
选项将这张表追加到 [My_Table.docx] 文档尾部;corr2docx
, t2docx
, reg2docx
命令添加后续表格.[My_Paper.docx]
在需要插入表格的地方写上[---------Table # Here--------]
,其中,# 表示表格编号;[My_Table.docx]
,
里面存放 [Table 1]
, [Table 2]
, .....我们需要把上述四个基本表格汇总至一份 word 文档里。
clear all
set more off
putdocx begin //新建 Word 文档
putdocx paragraph, halign(center) //段落居中
*-定义字体、大小等基本设置
putdocx text ("附:文中待插入表格"), ///
font("华为楷体",16,black) bold linebreak
*-保存名为 My_Table.docx 的 Word 文档
putdocx save "My_Table.docx", replace
*-调入数据
sysuse "auto.dta", clear
*-----Table 1-----
sum2docx price-length using "My_Table.docx", append ///
obs mean(%9.2f) sd min(%9.0g) median(%9.0g) max(%9.0g) ///
title("表 1: 描述性统计")
*-Note: 选项 append 的作用是将这张新表追加到 "My_Table.docx" 尾部, 下同.
*-----Table 2-----
putdocx begin
putdocx pagebreak
putdocx save "My_Table.docx", append
corr2docx price-length using "My_Table.docx", append ///
star(* 0.05) fmt(%4.2f) ///
title("表 2:相关系数矩阵")
*-----Table 3-----
putdocx begin
putdocx pagebreak
putdocx save "My_Table.docx", append
t2docx price-length using "My_Table.docx", append ///
by(foreign) title("表 3:组间均值差异 t 检验")
*-----Table 4-----
putdocx begin
putdocx pagebreak
putdocx save "My_Table.docx", append
reg price mpg weight length
est store m1
reg price mpg weight length foreign
est store m2
probit foreign price weight length
est store m3
reg2docx m1 m2 m3 using "My_Table.docx", append ///
r2(%9.3f) ar2(%9.2f) b(%9.3f) t(%7.2f) ///
title("表4: 回归结果")
shellout "My_Table.docx" //大功告成!打开生成的 Word 文档
结果如图:
为了方便各位复制文中的代码和命令,我们将本文涉及的 Stata 命令汇总到了一个 Do-file 中,各位可以到 『Stata 连享会•码云』 → 『快速输出论文表格』 项目中下载。
Note:产生如下推文列表的 Stata 命令为:
lianxh 结果输出
安装最新版lianxh
命令:
ssc install lianxh, replace
免费公开课
最新课程-直播课
专题 | 嘉宾 | 直播/回看视频 |
---|---|---|
⭐ 最新专题 | 文本分析、机器学习、效率专题、生存分析等 | |
研究设计 | 连玉君 | 我的特斯拉-实证研究设计,-幻灯片- |
面板模型 | 连玉君 | 动态面板模型,-幻灯片- |
面板模型 | 连玉君 | 直击面板数据模型 [免费公开课,2小时] |
⛳ 课程主页
⛳ 课程主页
关于我们
课程, 直播, 视频, 客服, 模型设定, 研究设计, stata, plus, 绘图, 编程, 面板, 论文重现, 可视化, RDD, DID, PSM, 合成控制法
等
连享会小程序:扫一扫,看推文,看视频……
扫码加入连享会微信群,提问交流更方便
✏ 连享会-常见问题解答:
✨ https://gitee.com/lianxh/Course/wikis
New!
lianxh
命令发布了:
随时搜索连享会推文、Stata 资源,安装命令如下:
. ssc install lianxh
使用详情参见帮助文件 (有惊喜):
. help lianxh