【if条件、for循环、数据框连接、表达矩阵画箱线图】

编程能力,就是解决问题的能力,也是变优秀的能力

From 生物技能树 R语言基础第七节

文章目录

  • 1.长脚本管理方式
    • if(F){....}
    • 分成多个脚本,每个脚本最后保存Rdata,下一个脚本开头清空再加载
  • 2.实战项目的组织方式
    • 方法(一)
    • 方法(二)
    • 在这里插入图片描述
  • 3.条件和循环
    • if条件语句
    • if(){ } 如果。。。就。。。
    • if(){ } else{ },如果。。。就。。。否则。。。
    • 重点:ifelse函数
    • ifelse()+str_detect(),王炸
    • 多个条件
    • case_when
    • 练习7-2
  • 4.for循环
    • 批量画图
    • 批量装包
  • 5.隐式循环
    • 矩阵/数据框的隐式循环-apply()族函数
    • lapply(list, FUN, …)
  • 思考题:
    • 1.如何挑出一个数里最大的5个?
  • 课后思考题:
    • 2.如何挑出一个表达矩阵里方差最大的1000个基因?(test2.Rdata里有表达矩阵)
  • 6.两个数据框的连接
    • inner_join:取交集
    • full_join:全连接
    • left_join:左连接
    • right_join:右连接
    • 练习7-3:
  • 7.表达矩阵画箱线图(难懂)
  • 8.一些顶呱呱的函数
    • 遇到报错困惑
      • 找不到文件
      • 找不到函数
      • 不存在包
      • 找不到对象
    • R语言重点
    • 1.match-----
    • 2.一些搞文件的函数----


1.长脚本管理方式

if(F){…}

1.if(F){....},则{ }里的代码被跳过
if(T){....},则{ }里的代码被运行
凡是带有{ }的代码,均可以被折叠。

if(F){
  a=1
  b=a^2
  d=a+b+a^2
}

if(T){
  a=1
  b=a^2
  d=a+b+a^2
}

#凡是带有{ }的代码,均可以被折叠。在这里插入图片描述
使用情况 1:例如下载数据的代码,保留但不反复运行

分成多个脚本,每个脚本最后保存Rdata,下一个脚本开头清空再加载

在这里插入图片描述

save(pd,exp,gpl,file = "steplouput.Rdata")
#把第一个脚本产生的几个有效变量存下来了,存到Rdata里边,下次直接load Rdata

rm(list = ls()) #每个脚本运行之前都记得清空环境变量哦

为什么用Rdata而不是表格文件来衔接
1.变量,自带变量名称,不需要赋值,也没有参数
2.表格文件,需要赋值,读取参数的不同会导致读取结果不同,不能在后续代码里同等处理。
3.Rdata可以一次保存多个变量,下次只需要一次load就能得到多个数据。
4.Rdata不仅可以保存数据框,还可以保存其他任何数据结构。

2.实战项目的组织方式

方法(一)

在这里插入图片描述

方法(二)

每一步设置一个文件夹,每一个文件夹里都有一个project,一个文件夹和另一个文件夹作为工作目录的时候就涉及到工作目录的切换了

#相对路径,不推荐使用绝对路径
../  工作目录的上一级,可以访问隔壁文件夹的project

在这里插入图片描述


3.条件和循环

if条件语句

if(){ } 如果。。。就。。。

(1)只有if没有else,那么条件是FALSE时就什么都不做
提示:if()的括号里是一个逻辑值,不可以是多个逻辑值组成的向量

i = -1
if (i<0) print('up')

[1] "up"

if (i>0) print('up')

理解下面代码
就是之前用来装包的代码

if(!require(tidyr)) install.packages('tidyr')

if(){ } else{ },如果。。。就。。。否则。。。

(2)有else

i = -1
if (i>0){
  print('+')
} else {
  print("-")
}

重点:ifelse函数

在这里插入图片描述

> ifelse(i>0,"+","-")
[1] "-"
> x = rnorm(3)
> x
[1] -1.6343950  0.1812335  0.4729793
> ifelse(x>0,"+","-")
[1] "-" "+" "+"

ifelse()+str_detect(),王炸

library(stringr)
samples = c("tumor1","tumor2","tumor3","normal1","normal2","normal3")
k1 = str_detect(samples,"tumor");k1
[1]  TRUE  TRUE  TRUE FALSE FALSE FALSE
ifelse(k1,"tumor","normal")
[1] "tumor"  "tumor"  "tumor"  "normal" "normal" "normal"
#此刻代码也不会报错,但是输出错误
samples = c("tumor1","tumor2","tumor3","normal1","normal2","normal3")
k2 = str_detect(samples,"normal");k2
[1] FALSE FALSE FALSE  TRUE  TRUE  TRUE
ifelse(k2,"tumor","normal")
[1] "normal" "normal" "normal" "tumor"  "tumor"  "tumor" 
#更改为
ifelse(k2,"normal","tumor")
[1] "tumor"  "tumor"  "tumor"  "normal" "normal" "normal"

多个条件

#else后面直接跟if就可以实现多个条件
i = 0
if (i>0){
  print('+')
} else if (i==0) {
  print('0')
} else if (i< 0){
  print('-')
}

[1] "0"
#两个==是比较运算

或者写嵌套,一样的效果

ifelse(i>0,"+",ifelse(i<0,"-","0"))

[1] "0"

case_when

#让代码变得容易读,最后一种情况~前面写T就行
x = c(-1,-1,4,5,2,0)
case_when(x > 0 ~ "A",
          x == 0 ~ "0",
            T ~ "B")
            
[1] "B" "B" "A" "A" "A" "0"

练习7-2

1.加载deg.Rdata,根据a、b两列的值,按照以下条件生成向量x:
#a< -1 且b<0.05,则x对应的值为down;
#a>1 且b<0.05,则x对应的值为up;
#其他情况,x对应的值为no
#统计up、down、no各出现了多少次
#提示:ifelse函数

#方法一
load("deg.Rdata")
k1 = deg$a < -1 & deg$b < 0.05
k2 = deg$a > 1 & deg$b < 0.05
x = table(case_when(k1 ~ "down",
          k2 ~ "up",
          T ~ "no"))
x
#也可以
load("deg.Rdata")
k1 = deg$a < -1 & deg$b < 0.05;table(k1)
k2 = deg$a > 1 & deg$b < 0.05;table(k2)
x = case_when(k1 ~ "down",
                  k2 ~ "up",
                  T ~ "no")
table(x)
#方法二
x = table(ifelse(k1,"down",ifelse(k2,"up","no")));x

 #运行结果
 down    no    up 
 1059 28863   853 

4.for循环

#对x里的每个元素i进行同一操作
格式:

for( i in x){

CODE

}
for( i in 1:4){
  print(i)
}

## [1] 1
## [1] 2
## [1] 3
## [1] 4

i遍历x的值,当运行完最后一个x的值的时候,就会停下

批量画图


#批量画图,#把画板分隔成4,#用4列画4张图
par(mfrow = c(2,2))
for(i in 1:4){
  plot(iris[,i],col = iris[,5])
}

在这里插入图片描述

批量装包

#批量装包
pks = c("tidyr","dplyr","stringr")
for(g in pks){
  if(!require(g,character.only = T))
    install.packages(g,ask = F,update = F)
}

5.隐式循环

矩阵/数据框的隐式循环-apply()族函数

1.apply 处理矩阵或数据框
apply(X, MARGIN, FUN, …)

其中X是数据框/矩阵名

MARGIN为1表示行,为2表示列,FUN是函数

对x的每一行/每一列进行FUN函数

rm(list = ls())
test<- iris[1:6,1:4]

apply(test, 2, mean) ##对每一列求平均值
apply(test, 1, sum)  ##对每一行求总和,结果是一个向量,上面的一行是向量的名字

lapply(list, FUN, …)

对列表/向量中的每个元素实施相同的操作

lapply(1:4,rnorm)

## [[1]]
## [1] -0.844006
## 
## [[2]]
## [1] 1.3602517 0.2277469
## 
## [[3]]
## [1]  0.5345012 -0.7476097 -0.8925600
## 
## [[4]]
## [1] -0.8469975  0.2791090 -0.5900125  0.3493904

#输出结果是list

思考题:

1.如何挑出一个数里最大的5个?

方法一:
  x = rnorm(30);x
  x <- sort(x,decreasing = T)
  head(x,5)
  
}

方法二:
  x = rnorm(30);x
  sort(x)
  tail(sort(x),5)

#[1] 2.430152 2.030683 1.338829 1.095946 0.754246

找topn差异基因的思路,有时候依靠排序就能很好的解决

课后思考题:

2.如何挑出一个表达矩阵里方差最大的1000个基因?(test2.Rdata里有表达矩阵)

1.计算每个基因的方差
2.每个基因的方差排序
3.最后1000个数字所对应的基因

#统计元素
x = list(a = 1:10,
         b = rnorm(16),
         c = seq(1,3,0.1))
lapply(x,length)

##$a
[1] 10
##$b
[1] 16
##$c
[1] 21
#查看数据类型

x = list(a = 1:10,
         b = rnorm(16),
         c = seq(1,3,0.1))
lapply(x,class)

##$a
[1] "integer"
##$b
[1] "numeric"
##$c
[1] "numeric"
x = list(a = 1:10,
         b = rnorm(16),
         c = seq(1,3,0.1))
sapply(x,sum)


##> sapply(x,sum)
         a          b          c 
55.0000000 -0.4830007 42.0000000 

6.两个数据框的连接

inner_join:取交集

> test1 <- data.frame(name = c('jimmy','nicker','Damon','Sophie'), 
+                     blood_type = c("A","B","O","AB"))
> test1
    name blood_type
1  jimmy          A
2 nicker          B
3  Damon          O
4 Sophie         AB
> test2 <- data.frame(name = c('Damon','jimmy','nicker','tony'),
+                     group = c("group1","group1","group2","group2"),
+                     vision = c(4.2,4.3,4.9,4.5))
> test2
    name  group vision
1  Damon group1    4.2
2  jimmy group1    4.3
3 nicker group2    4.9
4   tony group2    4.5
> library(dplyr)
> inner_join(test1,test2,by="name")
    name blood_type  group vision
1  jimmy          A group1    4.3
2 nicker          B group2    4.9
3  Damon          O group1    4.2
> 

full_join:全连接

##全连接:取并集,多出来的行空着NA
> full_join(test1,test2,by="name")
    name blood_type  group vision
1  jimmy          A group1    4.3
2 nicker          B group2    4.9
3  Damon          O group1    4.2
4 Sophie         AB   <NA>     NA
5   tony       <NA> group2    4.5

left_join:左连接

左边表里的留下,右边表里的舍去

#左连接:以左边的数据框为准,右边多余的去掉,并连接
> left_join(test1,test2,by="name")
> 
    name blood_type  group vision
1  jimmy          A group1    4.3
2 nicker          B group2    4.9
3  Damon          O group1    4.2
4 Sophie         AB   <NA>     NA

right_join:右连接

#右连接:以右边的数据框为准,左边多余的去掉,并连接

right_join(test1,test2,by="name")
    name blood_type  group vision
1  jimmy          A group1    4.3
2 nicker          B group2    4.9
3  Damon          O group1    4.2
4   tony       <NA> group2    4.5

练习7-3:

  1. 加载test1.Rdata,将两个数据框按照probe_id列连接在一起,按共同列取交集
load("test1.Rdata")
library(dplyr)
inner_join(dat,ids,by="probe_id")
  1. 找出logFC最小的10个基因和logFC最大的10个基因(symbol列就是基因名)
load("test1.Rdata")
library(dplyr)
#取交集两种方式
x = inner_join(dat,ids,by="probe_id")
或
x = merge(dat,ids,by="probe_id")
#正在对数据框 x 根据 logFC 列进行排序,并把排序后的数据框重新赋值给变量 x。
x = arrange(x,logFC)
#取出最大的前十个
head(x$symbol,10)
#取出最小的后十个
tail(x$symbol,10)

7.表达矩阵画箱线图(难懂)

#在R语言中,set.seed() 函数用于设置随机数生成器的种子

set.seed(10086)
rnorm(10)
# 表达矩阵

#设置随机种子
set.seed(10086)
#生成了随机数矩阵,共6,
创建一个63行的矩阵,包含从正态分布中抽取的18个随机数
exp = matrix(rnorm(18),ncol = 6)
#取整函数,或取小数点后几位,2为取小数点后2位
exp = round(exp,2)
#生成行名和列名
rownames(exp) = paste0("gene",1:3)
colnames(exp) = paste0("test",1:6)
#让1~3列数据都+1
exp[,1:3] = exp[,1:3]+1
exp
##输出结果
 print(exp)
      test1 test2 test3 test4 test5 test6
gene1  1.55  1.49  1.80 -0.37 -1.82 -1.62
gene2 -1.74  0.37  2.08  2.11 -0.22  1.42
gene3  1.57  1.25  1.32  2.49  0.58 -0.8

接下来进行变形的操作,让exp这个矩阵变成ggplot2可以接受的格式

首先需要把表达矩阵(宽型数据)变成长型数据:把所有的信息都置于同一行上
行名需要+1列另外放置,以防丢失

library(tidyr)
library(tibble)
library(dplyr)
#t() 函数用于转置矩阵,即交换矩阵的行和列。
dat = t(exp) %>%  
#将转置后的矩阵转换为数据框(data frame)  
  as.data.frame() %>%   
#这个函数将数据框的行名作为一列添加到数据框中。注意,这个函数是 tibble 包提供的,所以确保已经安装并加载了 tibble 
  rownames_to_column() %>%  
#mutate() 函数用于添加新的列到数据框中。这里,它添加了一个名为 group 的新列,该列是通过 rep() 函数重复 "control" "treat" 字符串来生成的,每个字符串重复3次。
  mutate(group = rep(c("control","treat"),each = 3)) 

分步进行宽变长:
先把矩阵转置
变成数据框
把rownames变成一列
手动设置一下组别

 pdat = dat%>% 
 pivot_longer(cols = starts_with("gene"),
              names_to = "gene",
              values_to = "count")
print(pdat)

也可以直接用宽变长的函数pivot_longer

cols=指要变成同一列的基因名

names_to指新的基因名那一列的列名

values_to指数值那一列的列名

剩下的内容会跟着一起变化

> print(pdat)
# A tibble: 18 × 4
   rowname group   gene  count
   <chr>   <chr>   <chr> <dbl>
 1 test1   control gene1  1.55
 2 test1   control gene2 -1.74
 3 test1   control gene3  1.57
 4 test2   control gene1  1.49
 5 test2   control gene2  0.37
 6 test2   control gene3  1.25
 7 test3   control gene1  1.8 
 8 test3   control gene2  2.08
 9 test3   control gene3  1.32
10 test4   treat   gene1 -0.37
11 test4   treat   gene2  2.11
12 test4   treat   gene3  2.49
13 test5   treat   gene1 -1.82
14 test5   treat   gene2 -0.22
15 test5   treat   gene3  0.58
16 test6   treat   gene1 -1.62
17 test6   treat   gene2  1.42
18 test6   treat   gene3 -0.81
library(ggplot2)
p = ggplot(pdat,aes(gene,count))+
  geom_boxplot(aes(fill = group))+
  theme_bw()
p

在这里插入图片描述

8.一些顶呱呱的函数

match()
dir()
file.create()
file.exists()
file.remove()

遇到报错困惑

找不到文件

原因:工作目录有问题,应该用project打开Rstudio,在写文件的时候用tab键自动补齐

找不到函数

用tab键自动补齐,检查函数名称,是否在R包里的函数,没有加载R包

不存在包

安装即可

找不到对象

引号,或赋值

R语言重点

在这里插入图片描述

1.match-----

2.一些搞文件的函数----


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/630070.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【微服务最全详解】

文章目录 微服务微服务的介绍微服务服务架构演变 微服务网关微服务的负载均衡微服务的容灾机制服务崩溃服务容灾机制微服务熔断机制微服务限流Sentinel怎么实现限流微服务限流算法1.令牌桶算法2.漏斗桶算法 服务监控日志收集 微服务 微服务的介绍 微服务是一种软件架构风格&a…

上班族兼职新篇章:10大实战攻略,轻松年赚1-20万

对于众多上班族而言&#xff0c;如何在工作之余赚取额外收入&#xff0c;开启自己的第一份副业&#xff0c;已成为许多人心中的疑问。每个人的才能和兴趣点不尽相同&#xff0c;但都有机会找到适合自己的兼职方式。接下来&#xff0c;就让我们一起探索这10大实战攻略&#xff0…

Google Ads谷歌广告账户被封停怎么办?

跨境出海业务少不了需要做Google Ads推广业务&#xff1b;其中让投手们闻风丧胆的消息就是帐户被暂停。当 Google 检测到任何违反其政策且可能损害用户在线体验的行为时&#xff0c;就会发生这种情况。那么如何在做广告推广的同时&#xff0c;保证账号不被封禁呢&#xff1f;看…

基于单片机的智能安防系统设计(32+4G+WIFI版)-设计说明书

设计摘要&#xff1a; 本设计基于STM32单片机&#xff0c;旨在实现一个智能安防系统&#xff0c;主要包括烟雾和温度传感器、人体红外传感器、显示屏、按键、4G模块和WiFi模块等组件。通过这些组件的协作&#xff0c;实现了火灾检测、入侵监测、状态显示、用户交互和远程通信等…

AI高清逼真换脸换装

在我们的最新AI换脸换装技术中&#xff0c;我们将高度真实的视觉效果与创新的人工智能技术相结合&#xff0c;提供了前所未有的个性化数字体验。无论是为了娱乐、广告、电影制作还是个人化虚拟体验&#xff0c;我们的技术都能让你的想象无缝转换为现实。通过我们的平台&#xf…

Linux命令使用

一、ls tree clear 1.1 ls ls&#xff1a;查看当前目录下的文件名ls 目录名&#xff1a;查看指定目录下的文件名ls /&#xff1a;查看根目录下的文件名ls -a&#xff1a;查看当前目录下的所有文件名&#xff0c;包括隐藏文件ls -l&#xff1a;查看当前目录下文件的详细信息…

Blender雕刻建模_笔刷纹理和顶点绘制

笔刷纹理 主要用于皮肤&#xff0c;纹理的雕刻。 可以修改映射方式来实现不同绘制效果。 用一张纹理来定义笔刷各个点的强度。其中白色为1&#xff0c;黑色为0。 设置笔刷纹理步骤&#xff1a; -新建一套笔刷 -强度&#xff0c;设为0.15&#xff08;可以根据需求修改&#x…

数据结构与算法笔记(一)---时间复杂度与空间复杂度

前言 以自述式的笔记展示&#xff0c;尽可能用最好理解的方式去叙述我对知识点的理解&#xff0c;方便有需求的小伙伴查看理解&#xff0c;同时锻炼自身的表达能力&#xff0c;共同学习&#xff0c;共同进步&#xff0c;争取“双赢”&#xff01; 注&#xff1a;本文章根据自…

Java面试八股之WeakHashMap的工作原理

简述WeakHashMap的工作原理 弱键&#xff08;Weak Keys&#xff09;&#xff1a; WeakHashMap 的键&#xff08;keys&#xff09;是通过 WeakReference 弱引用进行封装的。弱引用是一种特殊的引用类型&#xff0c;它不会阻止所引用的对象被垃圾收集器回收。这意味着&#xff…

机器人操作系统ROS2学习—控制小海龟运动

将Ubuntu系统和ROS2安装完成后&#xff0c;就可以进行调用小海龟运动了。 一、打开Ubuntu系统后&#xff0c;调用终端窗口。有3 种方法可以打开启动终端: 1、通过快捷键CtrAItT; 2、桌面左下角有个显示应用的菜单&#xff0c;点击后找到终端“Terminal”图标&#xff0c;打…

kubernetes二进制多master部署

文章目录 一、master02 节点部署&#xff08;在上期博客部署完成的情况下&#xff09;1、准备master02节点需要的文件2、修改配置文件kube-apiserver中的IP3、启动各服务并设置开机自启4、查看node节点状态 二、负载均衡部署1、配置load balancer集群双机热备负载均衡1.1 准备n…

英飞凌SiC模块为小米电动车提供动力

至2027年之际&#xff0c;SiC功率模块与裸片产品将荣耀登场&#xff0c;助力小米电动汽车新品SU7璀璨问世。英飞凌&#xff0c;这家业界翘楚&#xff0c;将倾其所能&#xff0c;为小米SU7 Max提供两颗HybridPACK Drive G2 CoolSiC 1200 V模块&#xff0c;如同给电动汽车的心脏注…

万字长文破解 AI 图片生成算法-Stable diffusion (第一篇)

想象一下&#xff1a;你闭上眼睛&#xff0c;脑海中构思一个场景&#xff0c;用简短的语言描述出来&#xff0c;然后“啪”的一声&#xff0c;一张栩栩如生的图片就出现在你眼前。这不再是科幻小说里才有的情节&#xff0c;而是Stable Diffusion——一种前沿的AI图片生成算法—…

OpenHarmony 实战开发——ArkUI容器类API介绍

容器类&#xff0c;顾名思义就是存储的类&#xff0c;用于存储各种数据类型的元素&#xff0c;并具备一系列处理数据元素的方法。在 ArkUI 开发框架中&#xff0c;容器类采用了类似静态的语言来实现&#xff0c;并通过 NAPI 框架对外提供。通过对存储位置以及属性的限制&#x…

Signal 即将成为JavaScript的一部分

什么是响应性&#xff1f; 在过去的几年中&#xff0c;响应性成为了所有现代前端框架以及React库的核心。 对于不熟悉前端开发的人来说&#xff0c;起初这可能是一个令人困惑的概念&#xff0c;因为它改变了常规的、自上而下的、从调用者到被调用者的顺序工作流。 在响应性范…

OpenAI春季发布会速览,盘点近30天AI大事件

OpenAI发布会速览 北京时间5月14日凌晨1点&#xff0c;OpenAI在官网举行了"春季更新"活动&#xff0c;推出了全新的旗舰模型“GPT-4o”&#xff0c; 这款模型具备处理文本、图片、视频、语音的全能处理能力&#xff0c;能实时响应用户需求&#xff0c;并进行语音回应…

Altium Designer封装库和元器件符号库下载与导入教程(SnapEDA 、Ultra Librarian、Alldatasheetcn)

1.AD封装库和元器件符号库下载网址 以下是一些全球热门的Altium Designer封装库和元器件符号库下载网址推荐&#xff1a; Altium Content Vault (现称为Altium Manufacturer Part Search)&#xff1a;这是Altium官方提供的元器件库&#xff0c;可以直接在Altium Designer中使用…

腾讯开源混元DiT文生图模型,消费级单卡可推理

节前&#xff0c;我们组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、今年参加社招和校招面试的同学。 针对大模型技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备面试攻略、面试常考点等热门话题进行了深入的讨论。 总结链接…

层次式体系结构概述

1.软件体系结构 软件体系结构可定义为&#xff1a;软件体系结构为软件系统提供了结构、行为和属性的高级抽象&#xff0c;由构成系统的元素描述、这些元素的相互作用、指导元素集成的模式以及这些模式的约束组成。软件体系结构不仅指定了系统的组织结构和拓扑结构&#xff0c;并…

速度与激情:Redis如何以核心数据结构驱动极致性能

关注微信公众号 “程序员小胖” 每日技术干货&#xff0c;第一时间送达&#xff01; 引言 Redis是一个开源的内存数据结构存储系统&#xff0c;它支持多种类型的数据结构&#xff0c;如字符串、散列、列表、集合、有序集合等。Redis以其出色的性能和低延迟特性而闻名&#xf…