R统计学1 - 基础操作入门问题1-20

这篇具有很好参考价值的文章主要介绍了R统计学1 - 基础操作入门问题1-20。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

R统计学入门基础问题

1. 如何生成100个高斯(正态)分布随机数

x <- rnorm(100, mean = 5, sd = 0.1)
x
# [1] 4.893534 5.046611 5.081097 4.979164 5.181700 5.038192 5.135376 5.173346 4.968877 4.986146
# [11] 4.946258 5.198199 5.055531 4.943075 5.073673 4.831518 5.020880 4.930038 5.069399 4.966239
# [21] 5.035919 4.748342 4.950412 5.098074 5.200755 5.016067 4.980694 5.092845 4.969212 5.166748
# [31] 5.063731 5.188161 5.067183 4.832255 4.948366 4.945234 5.281972 5.004589 5.052194 4.970655
# [41] 4.821950 5.172387 5.075971 4.881912 5.077742 4.959202 4.978079 5.071156 5.122046 5.099949
# [51] 5.056486 5.073163 4.986136 4.879002 5.035217 5.115133 5.170419 4.979108 4.999929 5.104167
# [61] 4.995740 5.136457 5.088393 5.068214 4.979342 4.862489 4.984418 4.851406 5.101475 5.009014
# [71] 4.955209 5.113826 4.993114 4.969778 5.174806 5.118025 4.940426 5.016818 5.008397 5.007662
# [81] 5.037553 4.841561 4.927540 4.792235 4.943234 5.025745 4.877301 5.006027 5.105440 4.816338
# [91] 5.078376 5.099721 4.976009 4.844325 4.920226 5.052165 5.042234 4.876854 5.053872 5.029314
mean(x)
# 5.015125
sd(x)
# 0.1027691
summary(x)
# Min. 1st Qu.  Median    Mean 3rd Qu.    Max. 
# 4.748   4.954   5.016   5.015   5.079   5.282 

2. 如何清除内存所有变量

rm(list = ls(all = TRUE))

3. 如何更改小数显示数字位数

pi <- 3.1415926
# digits支持1-22个数字,默认为7
options(digits = 4) 
pi
# 3.142

4. 如何通过R调用系统内程序

使用system()或shell.exec()函数启动程序

system(paste("C:/Program Files/Internet Explorer/iexplore.exe" ,"cran.r-project.org") , wait = FALSE)
system("notepad")

5. 如果本地升级R,不重装R包

其他目录安装R新版本,将就版本R程序的library目录下的R包复制至新的R library目录下,执行以下代码

update.packages()

6. 如何获取当前工作目录和设置工作目录

# 获取当前working directory
getwd()

# 设置工作目录
setwd("目录路径")

7. 如何保存当前工作

# 工作目录生成.RData文件
save.image()

# 保存R对象
pi <- 3.1415926
save(pi , file = "pi.data")

8. 如何获取本地安装的R包列表

.packages(all.available = TRUE)
# [1] "abind"                          "ade4"                          
# [3] "afex"                           "affy"                          
# [5] "affyio"                         "airway"                        
# [7] "ALL"                            "Amelia" 
......

9. 如何查看函数的代码

summary

# 查看类函数方法
methods(summary)
# [1] summary,ANY-method                             summary,CompressedIRangesList-method          
# [3] summary,DBIObject-method                       summary,FilterResults-method                  
# [5] summary,FilterRules-method                     summary,Hits-method

# 查看类函数lm方法代码
summary.lm
# function (object, correlation = FALSE, symbolic.cor = FALSE, 
#           ...) 
# {
#   z <- object
#   p <- z$rank
#   rdf <- z$df.residual
#   if (p == 0) {
#     r <- z$residuals
#     n <- length(r)
#     w <- z$weights
#     if (is.null(w)) {
#       rss <- sum(r^2)
#     }
#     else {
#       rss <- sum(w * r^2)
#       r <- sqrt(w) * r
#     }
#     resvar <- rss/rdf
#     ans <- z[c("call", "terms", if (!is.null(z$weights)) "weights")]
#     class(ans) <- "summary.lm"
#     ans$aliased <- is.na(coef(object))
#     ans$residuals <- r
#     ans$df <- c(0L, n, length(ans$aliased))
#     ans$coefficients <- matrix(NA_real_, 0L, 4L, dimnames = list(NULL, 
#                                                                  c("Estimate", "Std. Error", "t value", "Pr(>|t|)")))
#     ans$sigma <- sqrt(resvar)
#     ans$r.squared <- ans$adj.r.squared <- 0
#     ans$cov.unscaled <- matrix(NA_real_, 0L, 0L)
#     if (correlation) 
#       ans$correlation <- ans$cov.unscaled
#     return(ans)
#   }
#   if (is.null(z$terms)) 
#     stop("invalid 'lm' object:  no 'terms' component")
#   if (!inherits(object, "lm")) 
#     warning("calling summary.lm(<fake-lm-object>) ...")
#   Qr <- qr.lm(object)
#   n <- NROW(Qr$qr)
#   if (is.na(z$df.residual) || n - p != z$df.residual) 
#     warning("residual degrees of freedom in object suggest this is not an \"lm\" fit")
#   r <- z$residuals
#   f <- z$fitted.values
#   w <- z$weights
#   if (is.null(w)) {
#     mss <- if (attr(z$terms, "intercept")) 
#       sum((f - mean(f))^2)
#     else sum(f^2)
#     rss <- sum(r^2)
#   }
#   else {
#     mss <- if (attr(z$terms, "intercept")) {
#       m <- sum(w * f/sum(w))
#       sum(w * (f - m)^2)
#     }
#     else sum(w * f^2)
#     rss <- sum(w * r^2)
#     r <- sqrt(w) * r
#   }
#   resvar <- rss/rdf
#   if (is.finite(resvar) && resvar < (mean(f)^2 + var(c(f))) * 
#       1e-30) 
#     warning("essentially perfect fit: summary may be unreliable")
#   p1 <- 1L:p
#   R <- chol2inv(Qr$qr[p1, p1, drop = FALSE])
#   se <- sqrt(diag(R) * resvar)
#   est <- z$coefficients[Qr$pivot[p1]]
#   tval <- est/se
#   ans <- z[c("call", "terms", if (!is.null(z$weights)) "weights")]
#   ans$residuals <- r
#   ans$coefficients <- cbind(Estimate = est, `Std. Error` = se, 
#                             `t value` = tval, `Pr(>|t|)` = 2 * pt(abs(tval), rdf, 
#                                                                   lower.tail = FALSE))
#   ans$aliased <- is.na(z$coefficients)
#   ans$sigma <- sqrt(resvar)
#   ans$df <- c(p, rdf, NCOL(Qr$qr))
#   if (p != attr(z$terms, "intercept")) {
#     df.int <- if (attr(z$terms, "intercept")) 
#       1L
#     else 0L
#     ans$r.squared <- mss/(mss + rss)
#     ans$adj.r.squared <- 1 - (1 - ans$r.squared) * ((n - 
#                                                        df.int)/rdf)
#     ans$fstatistic <- c(value = (mss/(p - df.int))/resvar, 
#                         numdf = p - df.int, dendf = rdf)
#   }
#   else ans$r.squared <- ans$adj.r.squared <- 0
#   ans$cov.unscaled <- R
#   dimnames(ans$cov.unscaled) <- dimnames(ans$coefficients)[c(1, 
#                                                              1)]
#   if (correlation) {
#     ans$correlation <- (R * resvar)/outer(se, se)
#     dimnames(ans$correlation) <- dimnames(ans$cov.unscaled)
#     ans$symbolic.cor <- symbolic.cor
#   }
#   if (!is.null(z$na.action)) 
#     ans$na.action <- z$na.action
#   class(ans) <- "summary.lm"
#   ans
# }

10. 如何在R中使用科学计数法

1e10 == 10000000000
# TRUE

1.2e-4 == 0.00012
# TRUE

10. 如何在R中读取其他统计软件输入数据

使用 foreign 包,它可以读取 Minitab, S, SAS, SPSS, Stata, Systat, dBase 保存的数据。

foreign::read.spss()
foreign::read.S()
foreign::read.systat()

11. R如何读取excel数据

使用 foreign 包,它可以读取 Minitab, S, SAS, SPSS, Stata, Systat, dBase 保存的数据。

# 方法一,将excel数据保存为.csv文件
data <- read.csv("data.csv")

# 方法二,使用xlsReadWrite R包
data <- read.xls("data.csv")

# 方法三,使用RODBC包
library(RODBC)
file <− odbcConnectExcel ("rexceltest.xls")
data <− sqlFetch(file , "Sheet1")
close(file )

12. R如何快速保存输出结果至文本文件

使用sink()函数

data("mtcars")
sink(file = "mtcars.txt")

13. R如何将因子(factor)转换为数字

# f为因子对象
as.numeric(as.character(f))
# 或
as.numeric(levels(f))[as.integer(f)]

14. R如何可视化输入数据

打开可视化界面

data <- data.frame()
edit(data) # 或fix(data

R统计学1 - 基础操作入门问题1-20,R语言,r语言,windows,开发语言

15. R如何连接数据库读取数据

R支持基于SQL语言的关系数据库,RMySQL包提供MySQL数据库接口,RODBC包提供多种数据库接口(标准ODBC接口数据库)。经测试,Windows 平台上的 Microsoft SQL Server、Access、Oracle、MySQL、PostgreSQL,Linux 平台上的 MySQL、Oracle、PostgreSQL、SQLite 都有实际应用案例。

library(RODBC)
# 连接数据库
db <- odbcConnect("database_name", uid = "username", pwd = "password")
# 查询
stocks <- sqlQuery(db, "select * from quotes")
# 断开数据库连接
odbcClose(db)

16. R如何在一个变量中追加元素

x <- 1:10
x
# 1  2  3  4  5  6  7  8  9 10

# 元素1后面追加元素0
append(x, 0, after = 1)
# 1  0  2  3  4  5  6  7  8  9 10

# 元素5后面追加元素100
append(x, 100, after = 5)
# 1   2   3   4   5 100   6   7   8   9  10

17. R如何删除某行或某列数据

逗号在前删除行,逗号在后删除列,前面添加负号-

# 创建4x5矩阵
x <- data.frame(matrix(1:20, nrow = 4, byrow = 5))
x
#  X1 X2 X3 X4 X5
#1  1  2  3  4  5
#2  6  7  8  9 10
#3 11 12 13 14 15
#4 16 17 18 19 20

# 删除第1和第3行数据
x1 <- x[-c(1,3) ,]
x1
#  X2 X4 X5
#1  2  4  5
#2  7  9 10
#3 12 14 15
#4 17 19 20

# 删除第1和第3列数据
x2 <- x[, -c(1,3)]
x2
#  X2 X4 X5
#1  2  4  5
#2  7  9 10
#3 12 14 15
# 17 19 20

18. R如何判断dataframe是否相同

# 创建dataframe
d1 <- data.frame(num = 1:8, lib = letters[1:8])
d1
# num lib
# 1   1   a
# 2   2   b
# 3   3   c
# 4   4   d
# 5   5   e
# 6   6   f
# 7   7   g
# 8   8   h

d2 <- d1
# 将d2第3行第1列数值和第8行第2列数值赋值为2
d2[[3,1]] <- 2 -> d2[[8, 2]]
d2
# num lib
# 1   1   a
# 2   2   b
# 3   2   c
# 4   4   d
# 5   5   e
# 6   6   f
# 7   7   g
# 8   8   2

any(d1==d2)
# TRUE, 至少1个值相同返回为TRUE

all(d1==d2)
# FALSE, 全部值相同返回为TRUE

# 获取2个dataframe不相同元素位置
which(d1 != d2, arr.ind = TRUE)
# row col
# [1,]   3   1
# [2,]   8   2

19. R如何去除重复元素

使用unique()或duplicated()函数文章来源地址https://www.toymoban.com/news/detail-774326.html

a1 <- c(1:20, 1:5, 3:6)
a1
# 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20  1  2  3  4  5  3  4  5  6
unique(a1) 或 x <- x[!duplicated(x)]
# 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20

20. R如何删除list中元素

lst <- list("l1" = list("a"=1, "b"=2), "l2" = list("a"=1, "b"=2))
lst
# $l1
# $l1$a
# [1] 1
# 
# $l1$b
# [1] 2
# 
# 
# $l2
# $l2$a
# [1] 1
# 
# $l2$b
# [1] 2

# 删除l1中b元素
lst[["l1"]]["b"] <- NULL
# lst
# $l1
# $l1$a
# [1] 1
# 
# 
# $l2
# $l2$a
# [1] 1
# 
# $l2$b
# [1] 2

到了这里,关于R统计学1 - 基础操作入门问题1-20的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 统计学-R语言-5.3

    本篇文章即为概率与分布的最后一篇文章。 分位数函数是累积分布函数的反函数。 p-分位数是具有这样性质的一个值:小于或等于它的概率为p。 根据定义,中位数即50%分位数。 分位数通常用于置信区间的计算,以及与设计试验有关的势函数的计算。 下面给出一个置信区间

    2024年01月18日
    浏览(33)
  • 统计学-R语言-6.2

    本篇将继续介绍上篇所剩下的内容。 设两个总体的均值分别为1和2,从两个总体中分别抽取样本量为n1和n2的两个随机样本,其样本均值分别为 和 。估计两个总体均值之差(u1-u2)的点估计量显然是两个样本的均值之差( )。 两个总体均值的置信区间是由两个样本均值之

    2024年01月18日
    浏览(32)
  • 统计学-R语言-2.2

    本篇文章是将上篇得软件安装完,对其部分功能进行介绍。 在我们日常练习时会有.RData文件导入,并对其进行分析,下面是两种方导入.RData文件。 直接找到自己下载的.RData文件,双击进行打开即可。 上面得工具栏中找到文件。 在里面找到打开程序脚本,找到你所保存的.R

    2024年02月02日
    浏览(24)
  • 统计学-R语言-4.5

    本篇文章将继续对数据的类型做介绍,本片也是最后一个介绍数据的。 掌握描述多变量数据的分析方法:多维列联表、复式条形图、并列箱线图、点带图、多变量散点图(重叠散点图和矩阵式散点图)。 除了一维表、二维表,在实际中更多的是多维表,也就是多个变量交叉

    2024年02月01日
    浏览(37)
  • 统计学-R语言-7.1

    本章主题是假设检验(hypothesis testing)。与参数估计一样,假设检验也是对总体参数感兴趣,如比例、比例间的差异,均值、均值间的差异等, 估计的主要任务是找出参数值等于几, 假设检验的兴趣主要是看参数的值是否等于某个特定值,或者比较两组数据, 在数学推导上,

    2024年01月21日
    浏览(28)
  • 统计学-R语言-4.6

    本篇文章是对数据可视化的补充文章。 跳转至该篇博客 跳转至该篇博客 在上面两篇博客中,对单变量和双变量的列联表进行了实例展示,下面是对三维列联表进行实例。 行变量为被调查者所属社区和性别,列变量为态度的三维列联表: 生成行变量为被调查者性别和态度,

    2024年01月18日
    浏览(32)
  • 统计学-R语言-5.2

    本篇文章将继续上篇的进行介绍。 大数定理大数定理”的另一种表达方式是“均值定理”,其含义是,随机变量X多个观察值的均值会随着观察值的增加越发趋近于总体的期望值,中心极限定理进一步告诉我们,均值服从期望为μ 的正态分布。在各种测量试验中,我们一般都

    2024年01月18日
    浏览(34)
  • 统计学-R语言-4.3

    本篇介绍的是数值型数据怎么进行数据可视化,本篇介绍的有直方图、茎叶图、箱线图。 直方图(Histogram)用于描述连续型变量的频数分布,实际应用中常用于考察变量的分布是否对称;是否服从某种分布类型,如正态分布 直方图以矩形的面积表示各组段的频数或频率, 各

    2024年01月16日
    浏览(32)
  • 统计学-R语言-7.2

    本篇将继续上篇文章进行介绍。 小样本的检验 假定条件 小样本(n30) 总体服从正太分布 检验统计量的选择与总体方差是否已知有关 已知样本,均值经标准化后服从标准正态分布: 单样本t检验的效应量通常使用 Cohen的d统计量来度量,计算公式为: 该效应量表示样本均值与假

    2024年01月21日
    浏览(35)
  • 统计学-R语言-2.1

    上篇文章介绍了统计学-R语言的介绍,本篇文章介绍如何安装R软件。 可以登录官网,https://www.r-project.org/,点击此处跳转。 点进去下滑找到China,之后找任意一个链接地址进行下载即可。 我点的是第二个,进入后在红框中选择自己对应得版本进行下载。 第一次安装点击红框处

    2024年02月02日
    浏览(18)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包