长数据与宽数据的转换丨数析学院

问题:

在R中,如何将宽格式的数据集转换为长格式数据集?
「注:对于R里的许多函数,长格式的数据集可能比宽格式数据集更受欢迎,然而在SPSS中,宽格式数据集则更为常用。」

指南:

接下来,我们会对下列两套方法进行演示:

  • tidyr包的gather()函数和spread()函数,这也是reshape2包的一个新接口。
  • reshape2包的melt()和dcast()函数。

还有一些其他的方法也能达成上文的目标,但我们在这里不做介绍,因为它们用起来略显复杂:

  • R内置的reshape()函数,需要注意的是它并不来自于reshape2包。
  • stack()函数和unstack()函数。

示例:

下面几个数据集包含的数据一致,但数据的长宽格式不同,下文中我们将一一演示下列数据集格式之间的相互转换。

tidyr包

由“宽”转“长”

使用gather函数:


在该例子中,我们运用了control:cond2语句来选择列control、列cond2以及它们之间的所有数据列,这是基于列位置的选择方式,当然,你也可以通过直接输入列名来确定要加入整合的目标数值列,如:

如果你想要程序化地使用gather()函数,你也许需要用一个变量来代表要整合的目标列名。这时候你应当使用gather_()函数而不是gather(),从而先能够将列名转换为字符串。

选读部分:重命名并排序变量列中的因素层级。

由“长”转“宽”

使用spread函数:


选读部分:数据框美化。

因素型变量的层级次序决定了数据列的排列顺序,而层级次序也同样可以在重塑前被更改或是在之后被重新排序。

reshape2包:

由“宽”转“长”,使用melt函数:
Use melt:



下列为melt函数中的若干选项,灵活运用它们有时能简化我们的工作流程:



如果我们不对measure.vars进行设定,在melt过程中就是自动地将所有其他变量都作为id.vars。反之,如果我们不设定id.vars,所有的其他变量则会被视为id.vars。

如果我们没有对variable.name作明确指定,那么函数会默认地将整合后构建的列命名为"variable";如果不设定value.name,那么对应数值列的默认名称将是"measurement"。

选读部分:重命名变量列中的因素层级。


由“长”转“宽”

下列代码的主要思路是运用dcast函数对数据进行重塑,这个函数的目标对象针对于数据框,如果我们想对数组或矩阵进行类似的处理,请使用acast函数作为替代。


选读部分:数据框美化。

因素型变量的层级次序决定了数据列的排列顺序,而层级次序也同样可以在重塑前被更改或是在之后被重新排序。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • //我所经历的大数据平台发展史(三):互联网时代 • 上篇http://www.infoq.com/cn/arti...
    葡萄喃喃呓语阅读 51,525评论 10 200
  • 问题 在对于定类数据的分析中,我们有时需要通过样本概率检验总体概率是否不同于某个既定的概率值,或是对比分组数据的分...
    Datartisan数据工匠阅读 5,363评论 0 0
  • 1.与主程序混合在一起 2.写在XML中(建议使用这种方式) 用于显示数据,图片或者其他信息的组建叫做VIEW。 ...
    stonecutter阅读 2,972评论 0 0
  • 一大清早,巴图就被首领叫到总部办公室。首领正襟危坐,麻脸严肃,摒退其他人员,单独给巴图安排了一个神秘任务。 首领反...
    亦诺1阅读 3,590评论 6 21
  • (此种文体应为“涨工资体”) 我听说有种牛,不吃草,喜好吃星空。你知道星空这种东西,吃起来相当麻烦,星光灿烂则咯牙...
    木卫六六阅读 3,730评论 0 4