码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • python 服务器批处理得到PSSM矩阵


    1. 在linux上安装psiblast

    最好新建一个python环境,因为我发现conda安装blast默认的是python==3.6.11,可能会不小心把你的python版本改掉…然后你写好的代码全die了……

    1. conda create -n blast python==3.6.11
    2. source activate blast
    3. conda install -c bioconda blast

    2.下载并编译用于比对的大型蛋白质数据库

    nr和uniprot是比较通用的数据库:

    ftp://ftp.ncbi.nlm.nih.gov/blast/db/
    https://www.uniprot.org/downloads

    1)nr是ncbi收集的目前所有微生物的蛋白序列,是用来计算氨基酸一般情况下的频率的,160G

    2)uniprot90根据相似性做了一个去冗余,所以比nr要小很多,56G

    1. # 以uniprot90为例
    2. wget ftp://ftp.uniprot.org/pub/databases/uniprot/uniref/uniref90/uniref90.fasta.gz # 下载
    3. gzip -d uniref90.fasta.gz # 解压
    4. makeblastdb -in uniref90.fasta -parse_seqids -hash_index -dbtype prot # 编译

    解析完成后的样子:

    文件是这个样子:(只截取了一部分)

     

    3. 获取PSSM矩阵

    我的初始文件是:

    P00269.fasta是对单条蛋白质处理,里面的格式是:

     testset.fasta是对蛋白质集合批处理,里面的格式是(也可以单独蛋白质存为.fasta文件,由于blast只能处理单条蛋白糊,把这个集合知识归总的意思,第一步还是要生成单条蛋白质的.fasta文件,所以这个文件看个人意愿):

    1)单条蛋白质序列的处理方法

    1. import os
    2. os.system('psiblast -query dataset/P00269.fasta -db /PSSM/uniref90.fasta -num_iterations 3 -out_ascii_pssm /dataset/P00269.pssm')##这个蛋白质好慢呀

    2)批处理获取的方法

    1. import os
    2. file_name='/dataset/testset.fasta'
    3. Protein_id=[]
    4. with open(file_name,'r') as fp:
    5. i=0
    6. for line in fp:
    7. if i%2==0:
    8. # Protein_id.append(line[1:-1])
    9. id=line[0:-1]
    10. p=line[1:-1]
    11. with open ('/dataset/'+str(p)+'.fasta','a') as protein:
    12. protein.write(id)
    13. # protein.write()
    14. if i%2==1:
    15. seq=line[0:-1]
    16. with open ('/dataset/'+str(p)+'.fasta','a') as protein:
    17. protein.write('\n')
    18. protein.write(seq)
    19. i=i+1
    20. os.system('psiblast -query '+'/dataset/'+str(p)+'.fasta -db /PSSM/uniref90.fasta -num_iterations 3 -out_ascii_pssm /dataset/'+str(p)+'.pssm')

    ##PSSM真是太慢了,下面是只生成一个后的截图

     emmmm,在研究怎么把这个矩阵存入文件方便调用,今天应该会更新……但是他好慢啊,不想用了。

    参考文献:

    linux下用psiblast批量生成pssm矩阵_褚骏逸的博客-CSDN博客

  • 相关阅读:
    合理运用ChatGPT使用Python编写一个桌面便签应用
    由面试题“Redis是否为单线程”引发的思考
    猿创征文|工具百宝箱-编辑器-笔记工具-日常小工具-原型设计工具
    前端开发 开发过程
    Z-Score模型的进阶版:Zeta模型
    从小白到架构师(3): 揭开分布式数据库的面纱
    vue部分内置指令
    加速大模型落地!中兴通讯携手 1024 程序员节设立 AICon 人工智能大模型工程化论坛
    可视化Docker管理工具-DockerUI
    【无标题】This project has been opened by another efinity instance
  • 原文地址:https://blog.csdn.net/Daisy4/article/details/125876214
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号