# 读取文件
data <- read.csv("1vir.csv", header = TRUE)
# 检查数据列数是否足够
if (ncol(data) < 16) {
stop("数据列数少于 16 列")
}
# 将数据转换为数据框(确保是 data.frame 类型)
data <- as.data.frame(data)
# 创建一个新的数据框只包含第一列和第十六列,同时去除包含缺失值的行
new_data <- data.frame(
col1 = data[, 1][complete.cases(data[, c(1, 16)])],
col16 = data[, 16][complete.cases(data[, c(1, 16)])]
)
# 根据第一列合并第十六列(使用 aggregate 函数)
merged_data <- aggregate(col16 ~ col1, data = new_data, FUN = function(x) paste(x, collapse = ","))
# 重命名列
colnames(merged_data) <- c("第一列", "合并后的第十六列")
# 保存结果为新的 CSV 文件
write.csv(merged_data, "merged_data.csv", row.names = FALSE)
# 读取 CSV 文件
data <- read.csv("merged_data.csv", header = TRUE)
# 提取第一列和第二列
col1 <- data[, 1]
col2 <- data[, 2]
# 构建 FASTA 格式的字符串
fasta_str <- ""
for (i in 1:length(col1)) {
fasta_str <- paste0(fasta_str, paste0(">", col1[i], "\n", col2[i], "\n"))
}
# 保存为 FASTA 文件
write(fasta_str, file = "output.fasta")
###BiocManager::install("msa")
require(msa)
mySequenceFile <- readAAStringSet("output.fasta")
#多序列比对
myFirstAlignment <- msa(mySequenceFile)
head(mySequenceFile)
library(ggplot2)
require(seqinr)
myAlignment <- msaConvert(myFirstAlignment, type="seqinr::alignment")
d <- dist.alignment(myAlignment, "identity")
#构建NJ树
require(ape)
tree <- nj(d)
#画树并输出到PDF文件ggtree.pdf
require(ggtree)
环形进化树
##环状图
p1<-ggtree(tree, layout='circular', ladderize=FALSE, size=0.8, branch.length="none",col="red")+
geom_tiplab2(hjust=-0.3)+
geom_tippoint(size=1.5,col="blue")+
geom_nodepoint(color="black", alpha=1/4, size=2) +
theme(legend.title=element_text(face="bold"), legend.position="bottom", legend.box="horizontal", legend.text=element_text(size=rel(0.5)))
p1
# 图例位置、文字大小
###长方形图
p2<- ggtree(tree, layout='rectangular', size=0.8, col="deepskyblue3") +
geom_tiplab(size=3, color="purple4", hjust=-0.05)+
geom_tippoint(size=1.5, color="deepskyblue3")+
geom_nodepoint(color="pink", alpha=1/4, size=5)+
theme_tree2()
ggsave(p1, file="tree_circular.pdf", width=9, height=9)
ggsave(p2, file="tree_rectangular.pdf", width=9, height=9)
[R数据]提取序列,绘制fasta进化树
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- “进化树的构建怎么操作?”“那肯定是用MEGA啊!” 可是真的好麻烦啊,要先比对再建树,然后再进行各种美化,习惯了...
- 有时候,我们需要对某个特定基因家族进行进化树的构建,那么怎么来实现呢?以下是一种比较简单的基于Mega的方法 一 ...
- 通常我们会使用比对好的fasta文件构建进化树,fasta文件中大于号后的内容就是最终进化树上的文字标签。如果拿到...
- 这两天看用vcf文件做单倍型网络的内容,找到了一篇plos one上的论文 论文题目是 A workflow wi...