Bulk RNA-seq上下游分析

Bulk-RNA-seq上下游分析还是相对简单的,这次我以mouse为例,进行Bulk-RNA-seq上下游分析,并进行对应的图片绘制。

上游分析

1.软件准备

#安装所需软件
sudo apt install fastqc
sudo apt install hisat2
sudo apt install cutadapt
sudo apt install subread
conda install -c bioconda multiqc
conda install trim-galore
#新建文件夹
mkdir anntation bam cleandata genome QC rawdata results

2.文件准备

#下载fasta和gtf文件
wget -P genome/ -c https://ftp.ebi.ac.uk/pub/databases/gencode/Gencode_mouse/release_M25/GRCm38.p6.genome.fa.gz
wget -P anntation/ -c https://ftp.ebi.ac.uk/pub/databases/gencode/Gencode_mouse/release_M25/gencode.vM25.annotation.gtf.gz
gzip -dk genome/GRCm38.p6.genome.fa.gz #解压参考基因组
gzip -dk anntation/gencode.vM25.annotation.gtf.gz #解压基因注释文件
#Aspera下载fastq数据,比sra-tools快太多了,具体下载链接在EBI数据库中下载样本的TSV文件
#这里我们用的是单端SE测序的文件,挺古老,但是不管双端PE单端SE区别不大。
for i in {1..4}
doascp -i ~/.aspera/connect/etc/asperaweb_id_dsa.openssh -l 100M -T -P33001 -k 1 era-fasp@fasp.sra.ebi.ac.uk:/vol1/fastq/SRR137/00${i}/SRR137492${i}/SRR137492${i}.fastq.gz ./rawdata
done

3.trim_galore数据质控

通过fastqc质控,看一下测序数据的质量,看看哪些需要调整一下。fastq文件过滤这里我们用了trim_galore,除此之外fastp也很优秀,两者功能类似,但我认为fastp更好。

for i in 'ls ./rawdata/*.fastq.gz'
dofastqc $i -o QC/ --noextractmultiqc ./QC/*.zip -o ./QC./TrimGalore-0.6.7/trim_galore --quality 25 --fastqc --phred33 --length 25 -j 10 \--output_dir cleandata ${i}
done
#双端过滤可以加--paired,在末尾输入正反链

4.hisat2比对

比对用的hisat2,比较常用,其他的比对工具还有gencode数据库的star和tophat2等。

#比对
#构建fasta的index
hisat2-build genome/GRCm38.p6.genome.fa ./genome/mm10for i in 'ls cleandata/*.gz'
dox=${i%_trimmed.fq.gz}y=${x#cleandata/}hisat2 -p 10  -x genome/mm10  -U $i  -S bam/$y.sam |tee $y.alignment.log #比对samtools view -bS bam/$y.sam | samtools sort -@ 8 -o bam/$y-sort.bam #sortsamtools index bam/$y-sort.bam #索引
done
-p 线程
-U 单端测序,双端用-1 1.fa.gz -2 2.fq.gz
-S 输出bam文件名
-x 参考基因组

5.featureCounts定量


#计算count
featureCounts \-T 10 \-g gene_name \ #得到的count矩阵的行名,gene_id or gene_name比较常用-p \-a annotation/gencode.vM25.annotation.gtf \ #gtf基因注释文件-o results/final_featureCounts.txt \ #结果count矩阵bam/*.bam#-T 线程
#-g gtf第9列为key=value的格式,包括gene_id,gene_name等
#-p PE时计算fragment,SE时计算read(SE时read和fragment一样)

这样我们就得到后续下游分析所需的count矩阵了。

下游分析

在分析之前需要下载一系列的R包
install.packages( ) 下载一些常规的包
BiocManager::install( ) 下载bioconductor上的包

#说实话我忘记哪些包需要下载了,但是遇到没有的包用install.packages( )或BiocManager::install( )都试一遍就行。
install.packages('ggplot2')
install.packages('stingr')
BiocManager::install('DESeq2')
BiocManager::install('org.Mm.eg.db')
BiocManager::install('clusterProfiler')

1.文件预处理

注意DESseq2用的是原始的count矩阵,也就是上一步我们得到的结果,不需要对测序深度和基因长度进行处理(RPKM、FPRM、CPM)。也不需要normal化,DESeq2有一套自己的处理方法。

rm(list=ls())
options(stringsAsFactors = F)
library(DESeq2) #负二项分布的广义线性模型来做差异表达做检验#读取文件,final_featureCounts.txt为上一步得到的count矩阵数据
data <- read.table("final_featureCounts.txt", header=TRUE, skip=1, row.names=1)
#调整列名,最终数据行名为基因,列名为样本名,因为最开始输出的列名是bam文件的全名,所以gsub替换掉,仅保留样品名。
colnames(data) <- gsub(".bam", "", colnames(data), fixed=TRUE)
countdata <- data[ , 6:ncol(data)]
colnames(countdata)=gsub('.sort','',colnames(countdata))
#预过滤,基因至少在75%样品中表达,否则就过滤,看自己样本具体情况,最少也得40% or 50%吧。
countdata=countdata[rowSums(countdata>0) >= floor(0.75*ncol(countdata)),]#读取分组文件,样品的顺序和count矩阵中的要一致
metadata <- read.table("metadata.txt", header=TRUE,row.names = 1)
metadata$Group=factor(metadata$Group,levels = c('A','B'))

矩阵修剪后的结果如下,其实样品一般3v3比较好,这种2v2说服力还是差一些。
在这里插入图片描述
分组文件如下图
在这里插入图片描述

2.DESeq2差异分析

在差异分析过程中我们需要用cluster或者PCA看一下样品的聚类情况,以剔除不合群的样品,这个时候需要对矩阵进行一个类似log10(x+1)的处理,但这个处理后的数据仅仅是用来观察样品聚类情况,与我们进行的差异分析无关。

#DEseq2矩阵构建
dds <- DESeqDataSetFromMatrix(countData=countdata, colData=metadata, design=~Group)
#normalize
dds <- DESeq(dds)#PCA和cluster检查分组情况
library(ggplot2)
#rlog标准化,通过标准化矩阵看一下样品的PCA和显著性差异基因热图,对count整体标准化
dds_rlog <- rlog(dds, blind=FALSE)
#三种标准化的方法(DESeq2强烈不建议输入文件用归一化过的数据,这里这样处理主要是为了后续画PCA/热图/火山图等)
#1.ntd <- normTransform(dds)或log2(dds+1) 	    #简单的取log2(dds+1)(logarithm)
#2.rld <- rlog(dds, blind=FALSE) 			    #rlog适用于表达量分散以及低表达量占比高 (regularized logarithm)
#2.vsd <- vst(dds, blind=FALSE) 				#对于大样本,vsd更快(varianceStabilizingTransformation)
dds_rlog1=assay(dds_rlog) #用assay才能看具体矩阵大小
plotPCA(dds_rlog, intgroup="Group", ntop=5000) +theme_bw() + # 修改主体geom_point(size=5) + # 增加点大小#scale_y_continuous(limits=c(-10, 20)) +ggtitle(label="Principal Component Analysis (PCA)",subtitle="Top 500 most variable genes")
#cluster
plot(hclust(dist(t(dds_rlog1))), labels=colData(dds)$protocol)
plot(hclust(dist(t(dds_rlog1))), labels=colData(dds)$time)

PCA结果,利用这个图以及下面的cluster图,我们可以剔除一些离群的样本。
在这里插入图片描述
hclust函数利用欧氏距离计算的层次聚类图。
在这里插入图片描述

#差异分析
res <- results(dds, contrast=c("Group", "A", "B"), #谁和谁比对,前面是研究群体,后面的对照群体pAdjustMethod="fdr", alpha=0.05) #显著性方法
res <- na.omit(res)
res <- res[order(res$padj),] #res就是差异分析结果,用as.data.frame(res)可以转出来
summary(res)
mcols(res, use.names=TRUE)#保存差异分析结果,把counts在样本内做了标准化,从而使不同样本的同一个基因具有可比性
resdata <- merge(as.data.frame(res), as.data.frame(counts(dds, normalized=TRUE)), by="row.names", sort=FALSE)
write.csv(resdata, file="LoGlu_HiGlu_mm39_diff.csv", row.names=FALSE)#提取显著差异基因
diff_gene <- subset(res, padj < 0.05 & (log2FoldChange > 1 | log2FoldChange < -1))
write.table(x=as.data.frame(diff_gene), file="results_gene_annotated_significant.txt", sep="\t", quote=F, col.names=NA)

差异分析的阈值可以根据自己的数据来判断。一般就是取padj < 0.05, |logFC| > 1或2。

3.绘图

#Top40基因热图
mat <- assay(dds_rlog[row.names(diff_gene)])[1:40, ]
#选择用来作图的列,行名对应样品,Group列对应样品分组
annotation_col <- data.frame(Group=factor(colData(dds_rlog)$Group),row.names=rownames(colData(dds_rlog))
)
#定义颜色,Group列与上一步一致,定义具体分组标签对应的颜色
ann_colors <- list(Group=c(A="lightblue", B="darkorange")
)library(pheatmap)
library(RColorBrewer)
pheatmap(mat=mat, color=colorRampPalette(c('green','black',"red"))(20), scale="row", # Scale genes to Z-score (how many standard deviations)annotation_col=annotation_col, # Add multiple annotations to the samplesannotation_colors=ann_colors,# Change the default colors of the annotationsfontsize=6.5, # Make fonts smallercellwidth=55, # Make the cells widershow_colnames=F)

在这里插入图片描述

#差异基因与basemean关系
plotMA(res, ylim=c(-5, 5))
plotDispEsts(dds)#差异最大基因它们的normalized count的比较
top_gene <- rownames(res)[which.max(res$log2FoldChange)]
low_gene <- rownames(res)[which.min(res$log2FoldChange)]
plotCounts(dds=dds, gene=top_gene, intgroup="Group", normalized=TRUE, transform=TRUE)
plotCounts(dds=dds, gene=low_gene, intgroup="Group", normalized=TRUE, transform=TRUE)#差异分析基因的火山图
library(dplyr)
vol_data <- data.frame(gene=row.names(res),pval=-log10(res$padj),lfc=res$log2FoldChange)
# 设定上调与下调颜色
vol_data <- mutate(vol_data,color=ifelse(vol_data$lfc > 1 & vol_data$pval > 1.3 ,"Increased",ifelse(vol_data$lfc < -1 & vol_data$pval > 1.3 ,"Decreased",'nonsignificant'))
)
vol_data$pval[1:5]=325  #过低的p值截断
vol <- ggplot(vol_data, aes(x=lfc, y=pval, color=color))+ ggtitle(label="Volcano Plot", subtitle="Colored by fold-change direction") +geom_point(size=2.5, alpha=0.8, na.rm=T) +scale_color_manual(name="Directionality",values=c(Increased="red", Decreased="blue",nonsignificant="darkgray")) +theme_bw(base_size=14) +theme(legend.position="right") +xlab(expression(log[2]("A" / "B"))) +ylab(expression(-log[10]("adjusted p-value"))) +geom_hline(yintercept=1.3, colour="black",lty=2,lwd=0.3)+geom_vline(xintercept=c(-1,1), colour="black",lty=2,lwd=0.3)+scale_x_continuous(limits = c(-8,8))ggsave(vol,filename = '1.vol.pdf',width = 8,height = 6)

火山图中有个问题,就是某些基因的P值太小,有的时候p值还会等于0,这是因为数值超出的R显示的范围,我的建议是截断这些p值,不然过小的p值会导致图形很难看。
在这里插入图片描述

4.富集分析

富集分析其实通俗的讲就是看得到的基因是否真的比正常情况下随机分布的要多。比如某物种总基因3万,某通路总基因500,我们分析得到3000个基因,如果正常分布的话应该有50个基因落在这条通路中,但实际上落在这条通路的基因有100个,显著的高于正常情况,所显著富集。

rm(list = ls())#清空环境变量
options(stringsAsFactors = F)##字符不作为因子读入
library(org.Mm.eg.db)
library(clusterProfiler)
a=read.table('results_gene_annotated_significant.txt',header = T,check.names = F)#转基因格式,从symbol转ENTREZID,用到小鼠的db包
gene.df <- bitr(rownames(a), fromType="SYMBOL",toType="ENTREZID", OrgDb = "org.Mm.eg.db",drop =T) #小鼠db包
#KEGG
kk.diff<- enrichKEGG(gene         = gene.df$ENTREZID,organism     = 'mmu', #mmu是小鼠pvalueCutoff = 0.05,  #adjust ppAdjustMethod='fdr')  #p值矫正方法kk.diff@result$Description=gsub('\'','',kk.diff@result$Description)
write.table(kk.diff,file="2.KEGG.txt",sep="\t",quote=F,row.names = F)
#GO
kk <- enrichGO(gene = gene.df$ENTREZID,OrgDb = 'org.Mm.eg.db', pvalueCutoff =0.05, #qvalueCutoff =1,pAdjustMethod='fdr',ont="all", #BP,CC,MFreadable =T#,maxGSSize = 2000)
kk@result$Description=gsub('\'','',kk@result$Description)
write.table(kk,file="2.GO.txt",sep="\t",quote=F,row.names = F)  

enrich里的pvalue代表的是adj.pvalue,如果你需要的通路p值大于0.05,你可以pvalueCutoff = 1,qvalueCutoff =1 输出所有通路,然后自己在结果中筛选。实际上选择pvalue还是选择adjust pvalue看个人。
ont表示GO的种类,包括CC,MF,BP,也可以使用all全部输出。
maxGSSize表示通路的大小,默认只要500个基因以下的通路,自行选择,比如可以设置maxGSSize = 1000或者2000,再大的话就没有意义了。
之后就是绘图,有各种类型,包括基因数排序,p值排序,自己选择适合自己的就行。

##GO plot
a=read.table('2.GO.txt',header = T,sep = '\t')
library(stringr)
x=as.data.frame(str_split_fixed(a$GeneRatio,'/',n=2))
a$GeneRatio=as.numeric(x$V1)/as.numeric(x$V2)b=a[a$p.adjust<=0.05,]
b=b[order(b$Count,decreasing = T),]
b=b[10:1,]
b$Description=factor(b$Description,levels = b$Description)library(ggplot2)
p1=ggplot()+geom_point(data = b,aes(x=GeneRatio,y=Description,size=Count,color=p.adjust))+scale_y_discrete(position = 'right')+ #调整y轴坐标位置,right or leftscale_color_gradient(low = "#a313b9", high = "#ebdeed",name='P.adjust')+#low = "#E61F19", high = "#f6bdbb"theme_bw()+theme(plot.title = element_text(hjust = 0.5))+labs(y='',title = 'GO')+#facet_grid(ONTOLOGY~.,scales = 'free',space = 'free')+theme(plot.margin = margin(t=10,b=10,r=10,l=10))+theme(panel.grid = element_line(size=0.2))+scale_size_continuous(range = c(0.05,6)#,limits = c(20,600),breaks=c(100,300,500))
ggsave(p1,filename = '3.GO.pdf',width =7,height = 4.5)

在这里插入图片描述

rm(list = ls())#清空环境变量
options(stringsAsFactors = F)##字符不作为因子读入
a=read.table('2.KEGG.txt',header = T,sep = '\t')
a$Description=gsub(' - Mus musculus.+','',a$Description)
library(stringr)
x=as.data.frame(str_split_fixed(a$GeneRatio,'/',n=2))
a$GeneRatio=as.numeric(x$V1)/as.numeric(x$V2)b=a[a$pvalue<=0.05,]b=b[order(b$Count,decreasing = T),]b=b[10:1,]library(ggplot2)
p1=ggplot()+geom_point(data = b,aes(x=GeneRatio,y=Description,size=Count,color=pvalue))+scale_y_discrete(limits=b$Description)+scale_color_gradient(low = "red", high = "blue")+theme_bw()+theme(plot.title = element_text(hjust = 0.5))+labs(y='',title = 'KEGG')+theme(plot.margin = margin(t=10,b=10,r=10,l=10))+scale_size_continuous(range = c(0.2,5))+theme(panel.grid = element_line(size=0.2))ggsave(p1,filename = '3.KEGG.pdf',width =7.2,height = 4.5)

在这里插入图片描述

rm(list = ls())#清空环境变量
options(stringsAsFactors = F)##字符不作为因子读入
a=read.table('2.KEGG.txt',header = T,sep = '\t')
a$Description=gsub(' - Mus musculus.+','',a$Description)
library(stringr)
x=as.data.frame(str_split_fixed(a$GeneRatio,'/',n=2))
a$GeneRatio=as.numeric(x$V1)/as.numeric(x$V2)b=a[a$pvalue<=0.05,]b=b[order(b$pvalue,decreasing = F),]b=b[10:1,]library(ggplot2)
p1=ggplot()+geom_bar(data=b,aes(x=-log10(pvalue),y=Description),stat = 'identity',fill='#f3d130')+scale_y_discrete(limits=b$Description)+theme_bw()+scale_x_continuous(expand = c(0,0),limits = c(0,max(-log10(b$pvalue))+1))ggsave(p1,filename = '3.KEGG.pdf',width =7.2,height = 4.5)

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

腾讯云4核8G服务器性能如何多少钱一年?

腾讯云服务器4核8G配置优惠价格表&#xff0c;轻量应用服务器和CVM云服务器均有活动&#xff0c;云服务器CVM标准型S5实例4核8G配置价格15个月1437.3元&#xff0c;5年6490.44元&#xff0c;轻量应用服务器4核8G12M带宽一年446元、529元15个月&#xff0c;腾讯云百科txybk.com分…

Spring Security OAuth2.0 实现分布式系统的认证和授权

Spring Security OAuth2.0 实现分布式系统的认证和授权 1. 基本概念1.1 什么是认证&#xff1f;1.2 什么是会话&#xff1f;1.2.1 基于 session 的认证方式1.2.2 基于 token 的认证方式 1.3 什么是授权&#xff1f;1.3.1 授权的数据模型 1.4 RBAC 介绍 2. Spring Security2.1 S…

鸿蒙4.0开发笔记之DevEco Studio如何使用Previewer窗口预览器(一)

一、预览器作用 DevEco Studio预览器概况在HarmonyOS应用开发过程中&#xff0c;通过使用预览器&#xff0c;可以查看应用的UI效果&#xff0c;方便开发者实时查看应用的运行效果&#xff0c;随时调整代码。 二、打开Previewer预览器 1、正常启动 打开预览器的位置在DevEco…

Spring Boot - devtools 热部署

spring-boot-devtools是Spring Boot提供的一组开发工具&#xff0c;它旨在提高开发体验。这些工具包括应用程序的自动重新启动、自动刷新和远程调试等功能。下面是将spring-boot-devtools整合到Spring Boot应用程序中的步骤&#xff1a; 0、启用"Build project automatic…

4核8G服务器价格选择轻量还是CVM合适?

腾讯云服务器4核8G配置优惠价格表&#xff0c;轻量应用服务器和CVM云服务器均有活动&#xff0c;云服务器CVM标准型S5实例4核8G配置价格15个月1437.3元&#xff0c;5年6490.44元&#xff0c;轻量应用服务器4核8G12M带宽一年446元、529元15个月&#xff0c;腾讯云百科txybk.com分…

【论文阅读】A Survey on Video Diffusion Models

视频扩散模型&#xff08;Video Diffusion Model&#xff09;最新综述GitHub 论文汇总-A Survey on Video Diffusion Models。 paper&#xff1a;[2310.10647] A Survey on Video Diffusion Models (arxiv.org) 0. Abstract 本文介绍了AIGC时代视频扩散模型的全面回顾。简要介…

Redis7.2.3集群安装,新增节点,删除节点,分配哈希槽,常见问题

概念&#xff1a; 【Redis】高可用之三&#xff1a;集群&#xff08;cluster&#xff09; - 知乎 实操&#xff1a; Redis集群三种模式 主从模式 优势&#xff1a; 主节点可读可写 从节点只能读&#xff08;从节点从主节点同步数据&#xff09; 缺点&#xff1a; 当主节点…

基于java web的中小型人力资源管理系统

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

大模型之十二十-中英双语开源大语言模型选型

从ChatGPT火爆出圈到现在纷纷开源的大语言模型&#xff0c;众多出入门的学习者以及跃跃欲试的公司不得不面临的是开源大语言模型的选型问题。 基于开源商业许可的开源大语言模型可以极大的节省成本和加速业务迭代。 当前&#xff08;2023年11月17日)开源的大语言模型如下&#…

L1 频段卫星导航射频前端低噪声放大器芯片MS2659

产品简述 MS2659 是一款具有高增益、低噪声系数的低噪声放大器 (LNA) &#xff0c;支持 L1 频段多模式全球卫星定位&#xff0c;可以应用于 GPS 、 北斗二代、伽利略、 GLONASS 等 GNSS 导航接收机中。芯片采 用 SOT23-6 的封装形式。 主要特点 ◼ 支持北斗、 …

提升提测质量之研测共建 | 京东云技术团队

一、序 日常研测工作演绎 你是否也有同样的困惑&#xff1f; 跟进的需求&#xff0c;就在提测前一秒&#xff0c;被告知不能如期提测了&#xff0c;研测计划被打乱&#xff1b; 提测的功能&#xff0c;犹如遇到不好的购物体验&#xff0c;缺斤短两&#xff0c;与prd预期不符…

centos7 killall命令安装、使用

安装 在线安装命 输入下面命令 yum install psmisc -y Psmisc软件包包含三个帮助管理/proc目录的程序。 安装下列程序: fuser, killall,pstree和pstree.x11(到pstree的链接) fuser #显示使用指定文件或者文件系统的进程的PID。 killall #杀死某个名字的进程&#xff0c;它…

JUC工具类_CyclicBarrier与CountDownLatch

最近被问到CyclicBarrier和CountDownLatch相关的面试题&#xff0c;CountDownLatch平时工作中经常用到&#xff0c;但是CyclicBarrier没有用过&#xff0c;一时答不上来&#xff0c;因此简单总结记录一下 1.什么是CyclicBarrier&#xff1f; 1.1 概念 CyclicBarrier&#xff…

Codeforces Round 909 (Div. 3)(A~G)(启发式合并)

1899A - Game with Integers 题意&#xff1a;给定一个数 , 两个人玩游戏&#xff0c;每人能够执行 操作&#xff0c;若操作完是3的倍数则获胜&#xff0c;问先手的人能否获胜&#xff08;若无限循环则先手的人输&#xff09;。 思路&#xff1a;假如一个数模3余1或者2&#…

Failed to restart network.service: Unit network.service not found.

执行systemctl restart network命令&#xff0c;报错Failed to restart network.service: Unit network.service not found. 执行 yum install network-scripts命令 再次执行&#xff0c;正常

简单漂亮的首页

效果图 说明 这个首页我也是构思了很久&#xff0c;才想出这个界面&#xff0c;大家喜欢的话&#xff0c;可以拿走去使用 技术的话&#xff0c;采用的就是vue的语法&#xff0c;但是不影响&#xff0c;很多样式我都是直接手敲出来的 代码实现 标语 <!-- 标语 start-->&…

【面试经典150 | 数学】加一

文章目录 写在前面Tag题目来源解题思路方法一&#xff1a;加一 其他语言python3 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法&#xff0c;两到三天更新一篇文章&#xff0c;欢迎催更…… 专栏内容以分析题目为主&#xff0c;并附带一些对于本题涉及到的数据结…

基于SSM的项目管理系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

Java 12 及Tomcat 部署配置

使用的软件版本 1. Java12部署 和之前的Java版本不太一样&#xff0c;12版本不用配置JRE环境。 解压缩文件夹 root账户执行 tar -xzvf /home/software/jdk-12.0.2_linux-x64_bin.tar.gz创建java文件夹 root账户执行 cd /usr mkdir java移动Java文件到创建的文件夹下 root账…

达尔优EK87键盘说明书

EK87说明书连接说明&#xff1a; **有线模式&#xff1a;**开关拨到最右边&#xff0c;然后插线连接电脑即可使用 2.4G **接收器模式&#xff1a;**开关拨到中间&#xff0c;然后接收器插入电脑USB接口即可使用 **蓝牙模式&#xff1a;**开关拨到最左边&#xff0c;然后按FNQ长…