作者:朱磊 | 连玉君 |

Stata连享会 (知乎 | 简书 | 码云)

Stata连享会   计量专题 || 精品课程 || 简书推文 || 公众号合集


毫不夸张的讲, table 命令是 stata 中最基础的命令之一。说它基础并不是说这条命令不重要,或是用的少,恰恰相反,它就像空气和水一样,在我们的研究中不可或缺,但却十分容易被忽视。

曾今身边有小伙伴跟我说,他写文章从不 table ,更不 winsor ,其他的什么 twoway 啥的更是想都别想,他一般是在文献里看中了哪个酷炫的模型直接扣之,多扣几篇再加以整合,变量的处理皆为“前人经验”。这样做出的实证结果往往还相当令人满意,很少需要调整,最后论文同样发了一箩筐。因此,他对我等每日因为一个离群值而苦思冥想甚是不解,认为是在浪费生命。

实际上,做学问的套路因人而异,就像擂台上的拳手打法各不相同。这种先有研究方法,再倒逼研究目的的做法,尽管看似投机取巧,但只要能达到最终目的,有时我们也不必苛求。那么,问题来了,如果我们想做一个“老实人”,有了研究目的和研究对象后,再选择研究方法,该怎么做呢?问的好!那你必然是离不开这条 table 命令了。

连享会计量方法专题……

1. 引言

table 实际上相当常用,所以会常用,是因为它能在研究的最初就将各个变量观察值的特征简洁的展现出来,包括频数、均值和总额等,从而帮助我们选择研究方法和构建合适的模型,在一定程度上避免出现 “走弯路” 的现象。

先来看看文献中出现的表格长啥样:

范例1:徐鸿翔, 张文彬. 国家重点生态功能区转移支付的生态保护效应研究——基于陕西省数据的实证研究[J]. 中国人口·资源环境, 2017(11): 141-148.

[外链图片转存失败(img-cq6PT1eJ-1568941771888)(http://upload-images.jianshu.io/upload_images/7692714-7dd9b78cf05d3464.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 “QQ截图20180409044237.png”)]

这是《中国人口·资源环境》上的一篇文献中的表格,完全可以通过 table 命令生成后转置表格得到。我们再来看一篇:

范例2: 赵西亮. 教育、户籍转换与城乡教育收益率差异[J]. 经济研究, 2017(12): 164-178.

[外链图片转存失败(img-JbKgN8cz-1568941771889)(http://upload-images.jianshu.io/upload_images/7692714-a06d91f99683b0e2.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 “QQ截图20180409044327.png”)]

这是《经济研究》上的一篇文献,与表1有些不同,但同样也可以采用 table 命令实现。

原来这些牛×哄哄的期刊论文中,也能用我们小小的 table 来完成部分内容。此时的你是不是已经按捺不住内心的激动,迫切想知道 table 命令到底如何使用了呢?你一定是!

2. table 命令简介

table 命令主要是用来做列表统计,尤其对于类别变量的统计,使用的更加普遍。table 是 stata 的官方命令,无需另行下载。命令格式大致表示为:

[外链图片转存失败(img-NUGosBzG-1568941771890)(https://upload-images.jianshu.io/upload_images/7692714-e5a031e78e9ed10e.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

其中,if, in, weight 为可选项,用的少。 options 中可替换内容较多。一般用得多的有 contents(), format(), center, row, colum 等选项。

  • contents() 选项表示的是表格内所填数据为何。统计量名称在前,变量名称在后。要注意的是,当需要呈现多个统计量时,这两个名称需要成对在括号内出现多次。若不加此选项,stata默认变量统计量为频数。
  • format() 选项表示数据呈现格式。每个符号啥意思不知道没关系,背下来吧: format(%9.2f).
  • center 选项表示表内数据居中。
  • row 选项表示行末增加 total 统计量。
  • colum 选项表示列末增加 total 统计量。

table 命令后紧跟的 rowvar, colvar 和 supercolvar 分别表示行变量、列变量和超列变量(你也可以叫别的…),这三个变量可以填一个,也可以填多个。根据填入的变量的个数,可以把 table 表格划分为一维列表、二维列表和三维列表。

2.1 一维列表

所谓一维列表就是 table 后面只加了 rowvar 一个变量。以stata官方数据库为例,一维列表使用范例如下:
[外链图片转存失败(img-J1j5wArF-1568941771890)(https://upload-images.jianshu.io/upload_images/7692714-1f8a029bbbb25701.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]
输出结果如下:
[外链图片转存失败(img-yrbN6ITe-1568941771891)(https://upload-images.jianshu.io/upload_images/7692714-0436b5497ae921eb.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

表内汽车价格为国产车和进口车在各个统计量下的统计值。

2.2 二维列表

二维列表是指在 table 后面加入了 rowvar 和 colvar 两个变量。列表不仅在行方向上有变量,在列方向上也有变量控制。二维列表范例如下:

sysuse auto, clear
table foreign rep78,  ///c(mean price sd price min price max price n price) ///format(%9.2f) center row col

输出结果如下:
[外链图片转存失败(img-SSYJHBbC-1568941771891)(https://upload-images.jianshu.io/upload_images/7692714-80bf055de1c065d2.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

列表中的统计值可解释如:1978 年维修过 1 次的国产车均价为 4564.50美元。需要注意的是,当统计量不止一个时,stata 命令中的统计量书写顺序与列表中呈现的各列顺序要一一对应起来,以免出现错误。

连享会计量方法专题……

2.3 三维列表

三维列表是在二维列表的基础上,进一步加入了 supercolvar 变量。这时的列表已经比较复杂,要注意对行和列各变量含义的把握,构造出符合自身研究需要的列表。三维列表范例提供如下:

sysuse "nlsw88.dta", clear
table race married coll, ///c(mean wage) format(%9.2f)

[外链图片转存失败(img-CfQo45fC-1568941771891)(https://upload-images.jianshu.io/upload_images/7692714-795157a15b3d1b85.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

列表中呈现的是不同种族 (race)、不同学历 (coll_grad) 和不同婚姻状况(married) 下,妇女的平均工资。

2.3 四维列表

可以进一步在上述命令中增加 by() 选项,以便呈现四维表格:

table race married coll, by(union) ///c(mean wage) format(%9.2f)

输出结果为:
[外链图片转存失败(img-1FHumuRO-1568941771892)(https://upload-images.jianshu.io/upload_images/7692714-8807c36fa96a12ea.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

3. 列表输出

实际上,故事到此还并未结束。毕竟我们使用 table 命令做出列表的最终目的是运用于我们的论文中。因此,我们还需要将列表从 stata 窗口导出到 word 中。

要实现这一目的,当然,我们可以采用复制粘贴的办法,粘贴到 word 中后再逐步调整到我们需要的样子。然而,为了保证实证分析工作的可重复性,我么还是尽量使用命令来输出表格。

有两个外部命令可以完成这一工作:logoutasdoc

二者都是外部命令,因此都需要使用 ssc install 命令下载安装。以 asdoc 为例,我们可以通过 ssc install asdoc 或者 findit asdoc 来自行下载。

虽然 asdoc 在语法上更为简洁,也支持多张表依序放置在一个 Word 文档中,但就本文所列举的实例而言,使用 logout 输出结果更为稳定。

下面首先以 2.3 小节中介绍的三维列表为例,展示 asdoc 的方便快捷 —— 我们只需在制表命令前添加 asdoc 命令作为前缀即可:

asdoc table race married coll, ///c(mean wage) format(%9.2f)

如下是输出的 word 表格,显然,表头部分的信息并未得到妥善处理:
[外链图片转存失败(img-i1eQojvs-1568941771892)(https://upload-images.jianshu.io/upload_images/7692714-9270968a32ae57ab.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

事实上,由于本例中表头信息较为复杂,logout 也无法很好地处理表头信息:

logout, save(Table03) word fix(8) replace: ///
table race married coll, ///c(mean wage) format(%9.2f)

[外链图片转存失败(img-CpAuwlbu-1568941771893)(https://upload-images.jianshu.io/upload_images/7692714-1bd069f9b46c9d77.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

在这轮对比中,asdoc 似乎小胜一筹。然后,对于 2.2 小节中介绍的二维表格而言,asdoc 的输出结果则惨不忍睹,而 logout 则可以通过调整用于控制拆分敏感度的选项 fix(#) 得到较为满意的输出效果。

asdoc ///
table foreign rep78,  ///c(mean price sd price min price max price n price) ///format(%9.2f) center row col

[外链图片转存失败(img-0UqSCTmS-1568941771893)(https://upload-images.jianshu.io/upload_images/7692714-8239a2df5a23cb84.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

logout, save(Table02) word fix(3) dec(2) replace: ///
table foreign rep78,  ///c(mean price sd price min price max price n price) ///format(%9.2f) center row col

[外链图片转存失败(img-D8xPVlCq-1568941771893)(https://upload-images.jianshu.io/upload_images/7692714-493cd4ec7fc74e7d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)]

此时,我们在 logout 命令中将选项 fix() 里的数值设定为 3,同时设定了选项 dec(2) 以保证所有统计量都保留小数点后两位有效数字。当然,此时也有瑕疵:表中第五行 (每个组中的观察值个数) 被遗漏了。

连享会计量方法专题……

4. 其他相关命令

最后,再给大家列举几个与 table 命令相关的命令,感兴趣的话自行 help 。这些命令各自有自己的特色,但在部分功能上也有所重叠,总之,总有一款适合你。

  • tabulate 命令:会报告变量所占比重和累积比重,但只能用于一维和二维列表,多维列表的情况无法显示。
  • summarize 命令:主要用于一维列表的相关统计量的计算。
  • tabstat 命令:适用范围更加广泛,是生成论文第一张表:变量描述性统计的主要命令。
  • fsum 命令:快速生成论文中的第一张表,功能比 tabstat 更强大,尤其善于处理类别变量的列表统计。

连享会计量方法专题……

关于我们

  • 「Stata 连享会」 由中山大学连玉君老师团队创办,定期分享实证分析经验, 公众号:StataChina
  • 公众号推文同步发布于 CSDN 、简书 和 知乎Stata专栏。可在百度中搜索关键词 「Stata连享会」查看往期推文。
  • 点击推文底部【阅读原文】可以查看推文中的链接并下载相关资料。
  • 欢迎赐稿: 欢迎赐稿。录用稿件达 三篇 以上,即可 免费 获得一期 Stata 现场培训资格。
  • E-mail: StataChina@163.com
  • 往期推文:计量专题 || 精品课程 || 简书推文 || 公众号合集


Stata:今天你 “table” 了吗?图片版相关推荐

  1. java怎么给坦克上图片_Java坦克大战 (七) 之图片版

    在此小易将坦克大战这个项目分为几个版本,以此对J2SE的知识进行回顾和总结,希望这样也能给刚学完J2SE的小伙伴们一点启示! 坦克大战效果图: 坦克大战V0.7图片版实现功能: 1.将方向定义为一个E ...

  2. iview在table中添加图片

    我们知道iview的table封装的太好,如果只是展示数据简直不要太简单,但是比如合并单元格就很麻烦,而我要做的是在table中添加图片 建议大家先看一下这个:https://www.iviewui. ...

  3. Java坦克大战 (七) 之图片版

    本文来自:小易博客专栏.转载请注明出处:http://blog.csdn.net/oldinaction 在此小易将坦克大战这个项目分为几个版本,以此对J2SE的知识进行回顾和总结,希望这样也能给刚学 ...

  4. 建模示范视频EA022/社区团购系统试看片段-视频+图片版

    百度网盘下载试看片段,https://pan.baidu.com/s/1L-QGZGw7NuNdbzDT5kkqAg,提取码:umlc 试看视频 图片版

  5. 实验吧 —— web完整渗透测试实验指导书(图片版)

    web完整渗透测试实验指导书(图片版)

  6. 默默学计算机题库,2010年专转本计算机真题-打印版+-默默学+-图片版.doc

    2010年专转本计算机真题-打印版+-默默学+-图片版.doc 春节活动策划 酒店春节期间员工关怀活动安排 一.迎新年拔河比赛 活动时间:2月10日上午 活动地点:******** 二.除夕夜活动(2 ...

  7. 建模示范视频EA-027智慧公寓系统试看片段-视频+图片版

    DDD领域驱动设计批评文集>> <软件方法>强化自测题集>> <软件方法>各章合集>> 购买完整视频,请访问建模示范视频购买页面>&g ...

  8. 高端ARM微处理器芯片性能比较(图片版)

    高端ARM微处理器芯片性能比较(图片版) 2010年12月14日 [b] 高端ARM微处理器芯片性能比较(图片版)[/b] 转载于:http://bbs.imp3.net/thread-894970- ...

  9. 计算机网络图谱图试题,历年全国计算机等级考试四级网络笔试综合真题:图片版...

    二 .综合题(每空 2 分,共 40 分).请将每一个空的正确答案写在答题卡[1]~[20]序号的横线上,答在试卷上不得分. 1.计算并填写下表 2009年上半年全国计算机等级考试四级网络笔试试题:图 ...

  10. Android Studio掷骰子生成随机数(图片版)(Java)

    Android Studio掷骰子生成随机数(图片版)(Java) .xml <?xml version="1.0" encoding="utf-8"?& ...

最新文章

  1. MySQL进阶SQL优化
  2. Windows 脚本系列之四—映射网络盘脚本
  3. ASP连接MYSQL问题点解决
  4. P1083 [NOIP 2012]借教室
  5. 关于bhuman文件结构
  6. 十大经典排序算法最强总结(含JAVA代码实现),大厂 HR 如何面试
  7. eth0: ERROR while getting interface flags: No such device
  8. Google Earth Engine(GEE)计算湿度(WET)
  9. ffmpeg海康SDK流接入的支持
  10. 苹果好用的测试软件,Mac上有什么好用的Mac内存检测软件?
  11. C++核心准则T.10:为所有的模板参数定义概念
  12. ⅰsee是什么意思_see是什么意思?
  13. 计算机专业学生该如何提高自己?提升自己的专业技能?
  14. PIPIOJ1099PIPI的油田
  15. 怎么给领导做项目汇报
  16. GitHub使用中的错误及解决办法
  17. VINS-Mono视觉SLAM总体设计框架解读
  18. 分布式session会话Sticky Sessions
  19. nexus7 刷成kali linux,Nexus 6p 刷入Kali Linux Nethunter 2019.4方法
  20. Luogu 1315 【NOIP2011】观光公交 (贪心)

热门文章

  1. 知其然,而不知其所以然
  2. Channel closed; cannot ack/nack
  3. Java程序应用实例:“你好 Java”
  4. SHT30使用的学习过程1SHT30工作模式介绍
  5. android app启动图片 加动画效果,Android Studio开发APP启动程序时开屏简单动画效果快速有效解决方案...
  6. vb 计算机主板喇叭发声,主板蜂鸣器发声规律总结
  7. 从零搭建游戏服务器,拢共分几步?
  8. 磁盘配额和raid配置
  9. spring源码解析,vip视频解析源码
  10. 智能化安防视频监控行业发展是如何转变的?