频数表在统计学中是一个非常基本并且重要的概念,我们这里就来讲解它的基本用法。

首先我们需要载入数据,并查看数据的基本信息

  1. install.packages('vcd') #安装vcd包,其中有可以利用的数据Arthritis
  2. library(vcd)
  3. 载入需要的程辑包:grid
  4. > head(Arthritis)#################################################
  5. ID Treatment  Sex Age Improved
  6. 1 57   Treated Male  27     Some
  7. 2 46   Treated Male  29     None
  8. 3 77   Treated Male  30     None
  9. 4 17   Treated Male  32   Marked
  10. 5 36   Treated Male  46   Marked
  11. 6 23   Treated Male  58   Marked
  12. > class(Arthritis)################################################
  13. [1] "data.frame"
  14. > summary(Arthritis)##############################################
  15. ID          Treatment      Sex          Age          Improved
  16. Min.   : 1.00   Placebo:43   Female:59   Min.   :23.00   None  :42
  17. 1st Qu.:21.75   Treated:41   Male  :25   1st Qu.:46.00   Some  :14
  18. Median :42.50                            Median :57.00   Marked:28
  19. Mean   :42.50                            Mean   :53.36
  20. 3rd Qu.:63.25                            3rd Qu.:63.00
  21. Max.   :84.00                            Max.   :74.00

从结果中看以看出,Arthritis是一个data.frame结构的数据。其中ID和Age是numeric型的数据,其他三个都是factor型的数据。

创建一维列联表

  1. > a<-table(Arthritis$Improved)#创建一维列联表
  2. > class(a)                    #查看变量a的类型
  3. [1] "table"
  4. > a
  5. None   Some Marked
  6. 42     14     28

从结果中可以看出,就是如下的表格

None Some Marked
42 14 28

创建二维列联表

  1. > b<-table(Arthritis$Sex,Arthritis$Improved)
  2. > class(b)
  3. [1] "table"
  4. > b
  5. None Some Marked
  6. Female   25   12     22
  7. Male     17    2      6

结果是如下表格

  None Some Marked
Female 25 12 22
Male 17 2 6

 我们还可以将一维列联表a和二维列联表b转化成百分比的形式

  1. > prop.table(a)
  2. None      Some    Marked
  3. 0.5000000 0.1666667 0.3333333
  4. > prop.table(b)
  5. None       Some     Marked
  6. Female 0.29761905 0.14285714 0.26190476
  7. Male   0.20238095 0.02380952 0.07142857

给table添加边际和

  1. > addmargins(a)####################################
  2. None   Some Marked    Sum
  3. 42     14     28     84
  4. > addmargins(b)####################################
  5. None Some Marked Sum
  6. Female   25   12     22  59
  7. Male     17    2      6  25
  8. Sum      42   14     28  84
  9. > addmargins(prop.table(a))#########################
  10. None      Some    Marked       Sum
  11. 0.5000000 0.1666667 0.3333333 1.0000000
  12. > addmargins(prop.table(b))#########################
  13. None       Some     Marked        Sum
  14. Female 0.29761905 0.14285714 0.26190476 0.70238095
  15. Male   0.20238095 0.02380952 0.07142857 0.29761905
  16. Sum    0.50000000 0.16666667 0.33333333 1.00000000

只添加某个部分边际和

    1. > addmargins(prop.table(b),1)
    2. None       Some     Marked
    3. Female 0.29761905 0.14285714 0.26190476
    4. Male   0.20238095 0.02380952 0.07142857
    5. Sum    0.50000000 0.16666667 0.33333333
    6. > addmargins(prop.table(b),2)
    7. None       Some     Marked        Sum
    8. Female 0.29761905 0.14285714 0.26190476 0.70238095
    9. Male   0.20238095 0.02380952 0.07142857 0.29761905

[R语言统计]频数表的更多相关文章

  1. 通过R语言统计考研英语(二)单词出现频率

    通过R语言统计考研英语(二)单词出现频率 大家对英语考试并不陌生,首先是背单词,就是所谓的高频词汇.厚厚的一本单词,真的看的头大.最近结合自己刚学的R语言,为年底的考研做准备,想统计一下最近考研英语( ...

  2. R语言统计学习-1简介

    一. 统计学习概述 统计学习是指一组用于理解数据和建模的工具集.这些工具可分为有监督或无监督.1.监督学习:用于根据一个或多个输入预测或估计输出.常用于商业.医学.天体物理学和公共政策等领域.2.无监 ...

  3. R语言—统计结果输出至本地文件方法总结

    1.sink()在代码开始前加一行:sink(“output.txt”),就会自动把结果全部输出到工作文件夹下的output.txt文本文档.这时在R控制台的输出窗口中是看不到输出结果的.代码结束时用 ...

  4. R语言统计词频 画词云

    原始数据: 程序: #统计词频 library(wordcloud) # F:/master2017/ch4/weibo170.cut.txt text <- readLines("F ...

  5. R语言统计字符串的字符数ncahr函数

    函数计算字符数量,包括在一个字符串的空格的个数. 语法 nchar()函数的基本语法是: nchar(x) 以下是所使用的参数的说明: x - 向量输入. 示例 result <- nchar( ...

  6. R语言-简单线性回归图-方法

    目标:利用R语言统计描绘50组实验对比结果 第一步:导入.csv文件 X <- read.table("D:abc11.csv",header = TRUE, sep = & ...

  7. 手把手教你学习R语言

    本文为带大家了解R语言以及分段式的步骤教程! 人们学习R语言时普遍存在缺乏系统学习方法的问题.学习者不知道从哪开始,如何进行,选择什么学习资源.虽然网络上有许多不错的免费学习资源,然而它们多过了头,反 ...

  8. 【转】R语言知识体系概览

    摘要:R语言的知识体系并非语法这么简单,如果都不了R的全貌,何谈学好R语言呢.本文将展示介绍R语言的知识体系结构,并告诉读者如何才能高效地学习R语言. 最近遇到很多的程序员都想转行到数据分析,于是就开 ...

  9. R语言学习(一)前言

    本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/49768161 R是一个有着统计分析功能 ...

随机推荐

  1. DataTable.Compute()

    一.DataTable.Compute()方法說明如下 作用:          计算用来传递筛选条件的当前行上的给定表达式. 格式為:          Object Compute (string ...

  2. oc引入头文件

    建立.h的头文件(header file)命名为Hi.h,源码如下: #ifndef oc3_Hi_h #define oc3_Hi_h void sayHi(); #endif 建立.c的头文件(c ...

  3. Linux时间子系统(十三) Tick Device layer综述

    一.前言 时间子系统中的tick device layer主要涉及kernel/time/tick-*相关的文件,本文的主要内容就是从high level层次(不纠缠在具体的每行代码)描述tick d ...

  4. sql server中bit字段实现取反操作

    update Fct_StockMove set Disabled=Disabled^1 WHERE MoveId='DCE268E0-2CB3-4D17-AC4E-0046FB459CAD'; 1. ...

  5. 图像的线性空间滤波matlab实现

    1.线性空间滤波函数Z = imfilter(X,H,option1,option2,...) X为输入图像矩阵,H为m*n维的掩膜矩阵,H中的数据类型必须是double类型.掩膜矩阵可以是用户定义, ...

  6. 使用国内镜像composer安装laravel

    1.安装 Laravel,创建blog项目 首先先说一下直接安装的方法,要想使用这个方法,首先要FQ(这是我们的基本国情决定的).这样的安装方式有两种: ①.全局安装 使用命令Laravel Inst ...

  7. Codeforces Round #262 (Div. 2) C

    题目: C. Present time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...

  8. [svc] cisco router as ca server

    把cisco路由器配置成ca服务器 参考 clock set 10:00:00 Dec 23 2017 conf t crypto key generate rsa general-keys labe ...

  9. Linux下C语言使用openssl库进行加密

    在这里插一小节加密的吧,使用openssl库进行加密. 使用MD5加密 我们以一个字符串为例,新建一个文件filename.txt,在文件内写入hello ,然后在Linux下可以使用命令md5sum ...

  10. Golang学习途径总结

    最近要进入一个新团队,新团队对异步开发好像很重视,我对异步开发技术再次做了一调研,其中Golang,之前看过一次The way to go,感觉就是简化C加协程和通道,这次又重新翻起,首先看了一下&l ...