python?服務(wù)器批處理得到PSSM矩陣的問題
1. 在linux上安裝psiblast
最好新建一個python環(huán)境,因為我發(fā)現(xiàn)conda安裝blast默認(rèn)的是python==3.6.11,可能會不小心把你的python版本改掉…然后你寫好的代碼全die了……
conda create -n blast python==3.6.11 source activate blast conda install -c bioconda blast
2.下載并編譯用于比對的大型蛋白質(zhì)數(shù)據(jù)庫
nr和uniprot是比較通用的數(shù)據(jù)庫:
ftp://ftp.ncbi.nlm.nih.gov/blast/db/
https://www.uniprot.org/downloads
1)nr是ncbi收集的目前所有微生物的蛋白序列,是用來計算氨基酸一般情況下的頻率的,160G
2)uniprot90根據(jù)相似性做了一個去冗余,所以比nr要小很多,56G
# 以uniprot90為例 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 # 編譯
解析完成后的樣子:

文件是這個樣子:(只截取了一部分)

3. 獲取PSSM矩陣
我的初始文件是:

P00269.fasta是對單條蛋白質(zhì)處理,里面的格式是:

testset.fasta是對蛋白質(zhì)集合批處理,里面的格式是(也可以單獨(dú)蛋白質(zhì)存為.fasta文件,由于blast只能處理單條蛋白糊,把這個集合知識歸總的意思,第一步還是要生成單條蛋白質(zhì)的.fasta文件,所以這個文件看個人意愿):

1)單條蛋白質(zhì)序列的處理方法
import os
os.system('psiblast -query dataset/P00269.fasta -db /PSSM/uniref90.fasta -num_iterations 3 -out_ascii_pssm /dataset/P00269.pssm')##這個蛋白質(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真是太慢了,下面是只生成一個后的截圖

emmmm,在研究怎么把這個矩陣存入文件方便調(diào)用,今天應(yīng)該會更新……但是他好慢啊,不想用了。
參考文獻(xiàn):
到此這篇關(guān)于python服務(wù)器批處理得到PSSM矩陣的文章就介紹到這了,更多相關(guān)python服務(wù)器批處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python re庫的正則表達(dá)式入門學(xué)習(xí)教程
這篇文章主要給大家介紹了關(guān)于python re庫的正則表達(dá)式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
python jenkins 打包構(gòu)建代碼的示例代碼
這篇文章主要介紹了python jenkins 打包構(gòu)建代碼的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
python中使用iterrows()對dataframe進(jìn)行遍歷的實(shí)例
今天小編就為大家分享一篇python中使用iterrows()對dataframe進(jìn)行遍歷的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
使用Python腳本來獲取Cisco設(shè)備信息的示例
這篇文章主要介紹了編寫Python腳本來獲取Python腳本來獲取Cisco設(shè)備信息的教程,文中的示例是獲取一臺思科交換機(jī)的腳本,需要的朋友可以參考下2015-05-05
Python實(shí)時監(jiān)控網(wǎng)站瀏覽記錄實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Python實(shí)時監(jiān)控網(wǎng)站瀏覽記錄實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07

