From 04bd2fd47809388b4ad84028e97fe851d3ebeb44 Mon Sep 17 00:00:00 2001 From: luponzo86 Date: Sat, 29 Feb 2020 13:01:17 -0800 Subject: [PATCH] redefine prody.queryUniprot() to check for no internet connection --- rhapsody/features/PolyPhen2.py | 3 ++- rhapsody/features/Uniprot.py | 18 ++++++++++++++---- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/rhapsody/features/PolyPhen2.py b/rhapsody/features/PolyPhen2.py index b9ce7b2..4991395 100644 --- a/rhapsody/features/PolyPhen2.py +++ b/rhapsody/features/PolyPhen2.py @@ -8,10 +8,11 @@ import requests import datetime import numpy as np -from prody import LOGGER, queryUniprot +from prody import LOGGER from requests.adapters import HTTPAdapter from requests.packages.urllib3.util.retry import Retry from math import log +from .Uniprot import queryUniprot __author__ = "Luca Ponzoni" __date__ = "December 2019" diff --git a/rhapsody/features/Uniprot.py b/rhapsody/features/Uniprot.py index 0974a92..bbaad3c 100644 --- a/rhapsody/features/Uniprot.py +++ b/rhapsody/features/Uniprot.py @@ -9,6 +9,7 @@ import numpy as np import prody as pd from prody import LOGGER, SETTINGS +from prody.utilities import openURL from tqdm import tqdm from Bio.pairwise2 import align as bioalign from Bio.pairwise2 import format_alignment @@ -20,7 +21,16 @@ __email__ = "lponzoni@pitt.edu" __status__ = "Production" -__all__ = ['UniprotMapping', 'mapSAVs2PDB', 'seqScanning', 'printSAVlist'] +__all__ = ['queryUniprot', 'UniprotMapping', 'mapSAVs2PDB', + 'seqScanning', 'printSAVlist'] + + +def queryUniprot(*args, **kwargs): + """ + Redefine prody function to check for no internet connection + """ + _ = openURL('http://www.uniprot.org/') + return pd.queryUniprot(*args, **kwargs) class UniprotMapping: @@ -52,7 +62,7 @@ def refresh(self): delete precomputed alignments. """ # import Uniprot record and official accession number - self.fullRecord = pd.queryUniprot(self.acc) + self.fullRecord = queryUniprot(self.acc) self.uniq_acc = self.fullRecord['accession 0'] # import main sequence and PDB records rec = self.fullRecord @@ -393,7 +403,7 @@ def recoverPickle(self, filename=None, folder=None, days=30, **kwargs): pickle_path = os.path.join(folder, filename) if not os.path.isfile(pickle_path): # import unique accession number - acc = pd.queryUniprot(self.acc)['accession 0'] + acc = queryUniprot(self.acc)['accession 0'] filename = 'UniprotMap-' + acc + '.pkl' pickle_path = os.path.join(folder, filename) else: @@ -878,7 +888,7 @@ def seqScanning(Uniprot_coord, sequence=None): assert len(coord) < 3, "Invalid format. Examples: 'Q9BW27' or 'Q9BW27 10'." aa_list = 'ACDEFGHIKLMNPQRSTVWY' if sequence is None: - Uniprot_record = pd.queryUniprot(coord[0]) + Uniprot_record = queryUniprot(coord[0]) sequence = Uniprot_record['sequence 0'].replace("\n", "") else: assert isinstance(sequence, str), "Must be a string."