網(wǎng)站首頁 編程語言 正文
1. 在linux上安裝psiblast
最好新建一個(gè)python環(huán)境,因?yàn)槲野l(fā)現(xiàn)conda安裝blast默認(rèn)的是python==3.6.11,可能會(huì)不小心把你的python版本改掉…然后你寫好的代碼全die了……
conda create -n blast python==3.6.11
source activate blast
conda install -c bioconda blast
2.下載并編譯用于比對(duì)的大型蛋白質(zhì)數(shù)據(jù)庫
nr和uniprot是比較通用的數(shù)據(jù)庫:
ftp://ftp.ncbi.nlm.nih.gov/blast/db/
https://www.uniprot.org/downloads
1)nr是ncbi收集的目前所有微生物的蛋白序列,是用來計(jì)算氨基酸一般情況下的頻率的,160G
2)uniprot90根據(jù)相似性做了一個(gè)去冗余,所以比nr要小很多,56G
# 以u(píng)niprot90為例
wget ftp://ftp.uniprot.org/pub/databases/uniprot/uniref/uniref90/uniref90.fasta.gz # 下載
gzip -d uniref90.fasta.gz # 解壓
makeblastdb -in uniref90.fasta -parse_seqids -hash_index -dbtype prot # 編譯
解析完成后的樣子:
文件是這個(gè)樣子:(只截取了一部分)
3. 獲取PSSM矩陣
我的初始文件是:
P00269.fasta是對(duì)單條蛋白質(zhì)處理,里面的格式是:
testset.fasta是對(duì)蛋白質(zhì)集合批處理,里面的格式是(也可以單獨(dú)蛋白質(zhì)存為.fasta文件,由于blast只能處理單條蛋白糊,把這個(gè)集合知識(shí)歸總的意思,第一步還是要生成單條蛋白質(zhì)的.fasta文件,所以這個(gè)文件看個(gè)人意愿):
1)單條蛋白質(zhì)序列的處理方法
import os
os.system('psiblast -query dataset/P00269.fasta -db /PSSM/uniref90.fasta -num_iterations 3 -out_ascii_pssm /dataset/P00269.pssm')##這個(gè)蛋白質(zhì)好慢呀
2)批處理獲取的方法
import os
file_name='/dataset/testset.fasta'
Protein_id=[]
with open(file_name,'r') as fp:
i=0
for line in fp:
if i%2==0:
# Protein_id.append(line[1:-1])
id=line[0:-1]
p=line[1:-1]
with open ('/dataset/'+str(p)+'.fasta','a') as protein:
protein.write(id)
# protein.write()
if i%2==1:
seq=line[0:-1]
with open ('/dataset/'+str(p)+'.fasta','a') as protein:
protein.write('\n')
protein.write(seq)
i=i+1
os.system('psiblast -query '+'/dataset/'+str(p)+'.fasta -db /PSSM/uniref90.fasta -num_iterations 3 -out_ascii_pssm /dataset/'+str(p)+'.pssm')
##PSSM真是太慢了,下面是只生成一個(gè)后的截圖
emmmm,在研究怎么把這個(gè)矩陣存入文件方便調(diào)用,今天應(yīng)該會(huì)更新……但是他好慢啊,不想用了。
參考文獻(xiàn):
linux下用psiblast批量生成pssm矩陣
原文鏈接:https://blog.csdn.net/Daisy4/article/details/125876214
相關(guān)推薦
- 2022-11-01 Python如何使用qrcode生成指定內(nèi)容的二維碼并在GUI界面顯示_python
- 2023-02-09 C++存儲(chǔ)鏈接性原理詳解_C 語言
- 2023-02-27 python定時(shí)任務(wù)schedule庫用法詳細(xì)講解_python
- 2023-10-15 [element-ui] el-input 不能正常輸入,輸入了也不能刪除的問題
- 2022-10-17 .Net?Core使用Coravel實(shí)現(xiàn)任務(wù)調(diào)度的完整步驟_實(shí)用技巧
- 2023-06-03 C/C++中#define的妙用分享_C 語言
- 2022-01-31 關(guān)于el-form中的rules未生效問題的解決方法
- 2022-10-22 Python中的Unittest基本使用_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支