當前位置: 首頁>>代碼示例>>Python>>正文


Python Entrez.email方法代碼示例

本文整理匯總了Python中Bio.Entrez.email方法的典型用法代碼示例。如果您正苦於以下問題:Python Entrez.email方法的具體用法?Python Entrez.email怎麽用?Python Entrez.email使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Bio.Entrez的用法示例。


在下文中一共展示了Entrez.email方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get_ncbi_seq

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_ncbi_seq(email, db, rettype, accession):

    # fetch
    print("Fetching accession %s from GenBank\n" % (accession))

    Entrez.email = email

    try:
        handle = Entrez.efetch(
            db=db,
            rettype=rettype,
            retmode="text",
            id=accession
        )
        res = handle.read()

        # for testing only
        # pickle_item(res, accession)
        return res

    except Exception:
        sys.stderr.write("Error! Cannot fetch: %s        \n" % accession) 
開發者ID:phageParser,項目名稱:phageParser,代碼行數:24,代碼來源:add_organism.py

示例2: main

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def main():
    parser = argparse.ArgumentParser(
        description='Populate the phageParser database with data from NCBI'
    )
    parser.add_argument(
        'email',
        nargs=1,
        help=('your email address (does not need to be registered, '
              'just used to identify you)')
    )
    args = parser.parse_args()

    Entrez.email = args.email

    print("Starting organism population")
    populate_organism()
    print("Starting LSR population")
    populate_lsrpair()
    print("Starting AntiCRISPR population")
    populate_anticrispr() 
開發者ID:phageParser,項目名稱:phageParser,代碼行數:22,代碼來源:populate.py

示例3: fetch_chrom_name

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def fetch_chrom_name(id):
    try:
        if not id.startswith("NC_"):
            return id
        Entrez.email = "vcf-kit@vcf-kit.com"
        chrom = Entrez.read(Entrez.efetch(db="nuccore", id=id, rettype="gb", retmode="xml"))
        gb_feature_quals = chrom[0]["GBSeq_feature-table"][0]["GBFeature_quals"]
        features = dict([x.values() for x in gb_feature_quals])
        if "organelle" in features:
            if features["organelle"] == "mitochondrion":
                return "MtDNA"
        else:
            chrom_name = features["chromosome"]
            return chrom_name
    except:
        return id 
開發者ID:AndersenLab,項目名稱:VCF-kit,代碼行數:18,代碼來源:genome.py

示例4: __init__

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def __init__(self, prefix, datasource, outdb, options=None, ohost=None,
                 email=None):
        '''
        prefix - prefix used to recognise which annotation is being performed
        datasource - link used for API
        outdb - output database
        options - optional string to be parsed by the APIAnnotation subclass
        ohost - original species of interest used by some subclasses
        email - entrez requires an email address to use its API
        '''
        self.prefix = prefix
        self.datasource = datasource
        self.outdb = outdb
        self.options = options
        self.ohost = ohost
        self.email = email
        self.resultsz = dict()
        self.resultspd = dict() 
開發者ID:CGATOxford,項目名稱:CGATPipelines,代碼行數:20,代碼來源:PipelineGeneInfo.py

示例5: get_species_from_taxid

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_species_from_taxid(self, taxid):
        #if it is an integer (a taxid), try to get the species name
        species = taxid
        if taxid.isdigit():
            Entrez.email = EMBL.PREVIOUS_VALUES["email"]
            # fetch the classification sufing the taxid
            logging.debug("Fetch The Lineage using Entrez.efetch")
            try:
                search = Entrez.efetch(id=taxid, db="taxonomy", retmode="xml")
                data = Entrez.read(search)
                species = data[0]['ScientificName']
            except IOError as e:
                logging.error("Could not get species from taxid: %s" % e)

        return "%s%s" % (species[0].upper(), species[1:].lower())

    #if species is a taxid we change by the species name 
開發者ID:NBISweden,項目名稱:EMBLmyGFF3,代碼行數:19,代碼來源:EMBLmyGFF3.py

示例6: get_taxid_from_species

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_taxid_from_species(self, species):
        #if it is a species name try to get the taxid
        taxid = species
        if not species.isdigit():
            Entrez.email = EMBL.PREVIOUS_VALUES["email"]
            #fetch taxid from ncbi taxomomy
            logging.debug("Fetch the taxid from species name using Entrez.esearch")
            species =  species.replace(" ", "+").strip()
            try:
                search = Entrez.esearch(term=species, db="taxonomy", retmode="xml")
                record = Entrez.read(search)
                if not record['IdList']: #no taxid found
                    logging.warning("Please verify the species name. '%s' species is unknown into the NCBI taxonomy databse. Impossible to check the taxonomic classification. We will use the default value 'Life' to populate the OC line.",self.species)
                    taxid=None
                else:
                    taxid = record['IdList'][0]
            except IOError as e:
                logging.error("Could not get taxid from species: %s" % e)

        return taxid 
開發者ID:NBISweden,項目名稱:EMBLmyGFF3,代碼行數:22,代碼來源:EMBLmyGFF3.py

示例7: parse

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def parse(self, path, fname, ftype, email, **kwargs):
        if self.accessions is not None:
            accessions = [acc.strip() for acc in self.accessions.split(",")]
            self.entrez_email(email)
            gi = self.get_GIs(accessions)
            viruses, sequences = self.get_entrez_viruses(gi, **kwargs)
        elif ftype is not None and fname is not None:
            if ftype == 'genbank':
                viruses, sequences = self.parse_gb_file(path + fname, **kwargs)
            elif ftype == 'accession':
                accessions = self.parse_accession_file(path + fname, **kwargs)
                self.entrez_email(email)
                gi = self.get_GIs(accessions)
                viruses, sequences = self.get_entrez_viruses(gi, **kwargs)
            elif ftype == 'fasta':
                viruses, sequences = self.parse_fasta_file(path + fname, **kwargs)
            elif ftype == 'tsv':
                viruses, sequences = self.parse_tsv_file(path + fname, **kwargs)
                print("Parsed " + str(len(viruses)) + " viruses and " + str(len(sequences)) + " sequences from file " + path+fname)
        else:
            raise Exception("No input file name and type defined or accessions given")
        return (viruses, sequences) 
開發者ID:nextstrain,項目名稱:fauna,代碼行數:24,代碼來源:parse.py

示例8: get_args

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_args():
    """get command-line arguments"""
    parser = argparse.ArgumentParser(
        description='Filter FASTA by taxons',
        formatter_class=argparse.ArgumentDefaultsHelpFormatter)

    parser.add_argument('file', metavar='str', help='Input file')

    parser.add_argument('-t',
                        '--taxa',
                        help='Taxa ids/file',
                        metavar='str',
                        type=str,
                        required=True)

    parser.add_argument('-e',
                        '--email',
                        help='Email address for Entrez query',
                        metavar='str',
                        type=str,
                        default='kyclark@email.arizona.edu')

    parser.add_argument('-o',
                        '--outfile',
                        help='Output file',
                        metavar='str',
                        type=str,
                        default='seqs.fa')

    parser.add_argument('-d', '--debug', help='Debug', action='store_true')

    return parser.parse_args()


# -------------------------------------------------- 
開發者ID:kyclark,項目名稱:bioinformatics_primer,代碼行數:37,代碼來源:solution.py

示例9: fetch_from_entrez

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def fetch_from_entrez(index, cache_dir=False):
    logger = logging.getLogger('build')

    # slugify the index for the cache filename (some indices have symbols not allowed in file names (e.g. /))
    index_slug= slugify(index)
    cache_file_path = '{}/{}'.format('/'.join(cache_dir), index_slug)

    # try fetching from cache
    if cache_dir:
        d = fetch_from_cache(cache_dir, index_slug)
        if d:
            logger.info('Fetched {} from cache'.format(cache_file_path))
            return d
    
    # if nothing is found in the cache, use the web API
    logger.info('Fetching {} from Entrez'.format(index))
    tries = 0
    max_tries = 5
    while tries < max_tries:
        if tries > 0:
            logger.warning('Failed fetching pubmed {}, retrying'.format(str(index)))
            
        try:
            Entrez.email = 'info@gpcrdb.org'
            handle = Entrez.efetch(
                db="pubmed", 
                id=str(index), 
                rettype="medline", 
                retmode="text"
            )
        except:
            tries += 1
            time.sleep(2)
        else:
            d = Medline.read(handle)

            # save to cache
            save_to_cache(cache_dir, index_slug, d)
            logger.info('Saved entry for {} in cache'.format(cache_file_path))
            return d 
開發者ID:protwis,項目名稱:protwis,代碼行數:42,代碼來源:tools.py

示例10: last_exception

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def last_exception():
    """Return last exception as a string, or use in logging."""
    exc_type, exc_value, exc_traceback = sys.exc_info()
    return "".join(traceback.format_exception(exc_type, exc_value, exc_traceback))


# Set contact email for NCBI 
開發者ID:widdowquinn,項目名稱:pyani,代碼行數:9,代碼來源:genbank_get_genomes_by_taxon.py

示例11: set_ncbi_email

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def set_ncbi_email(args: Namespace) -> None:
    """Set contact email for NCBI.

    :param args:  Namespace, command-line arguments
    """
    logger = logging.getLogger(__name__)

    Entrez.email = args.email
    logger.info("Set NCBI contact email to %s", args.email)
    Entrez.tool = "genbank_get_genomes_by_taxon.py"


# Create output directory if it doesn't exist 
開發者ID:widdowquinn,項目名稱:pyani,代碼行數:15,代碼來源:genbank_get_genomes_by_taxon.py

示例12: get_tax_id

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_tax_id(self, query_name):
        """to get data from ncbi taxomomy, we need to have the taxid. we can
        get that by passing the species name to esearch, which will return
        the tax id"""
        query_name = query_name.replace(' ', "+").strip()
        Entrez.email = 'A.N.Other@example.com'
        search = Entrez.esearch(term=query_name, db="taxonomy", retmode="xml")
        record = Entrez.read(search)
        return record['IdList'][0] if record['IdList'] else None 
開發者ID:dongzhang0725,項目名稱:PhyloSuite,代碼行數:11,代碼來源:handleGB.py

示例13: get_tax_data

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def get_tax_data(self, taxid):
        """once we have the taxid, we can fetch the record"""
        Entrez.email = 'A.N.Other@example.com'
        search = Entrez.efetch(id=taxid, db="taxonomy", retmode="xml")
        return Entrez.read(search) 
開發者ID:dongzhang0725,項目名稱:PhyloSuite,代碼行數:7,代碼來源:handleGB.py

示例14: fetSeqFromNCBI

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def fetSeqFromNCBI(self, id_array):
        batch_size = 20
        count = len(id_array)
        download_contents = ""
        for start in range(0, count, batch_size):
            if self.interrupt:
                return
            end = min(count, start + batch_size)
            print("Going to download record %i to %i" % (start + 1, end))
            if (start + batch_size) > count:
                batch_size = count - start
            Entrez.email = self.email if self.email else "A.N.Other@example.com"
            fetch_handle = Entrez.efetch(db="nucleotide", rettype=self.rettype, retmode="text",
                                         retstart=start, retmax=batch_size, id=id_array)
            download_contents += fetch_handle.read()
            self.progressDiologSig.emit(end * 100 / count)
        if self.rettype == "gb":
            self.inputContentSig.emit(
                download_contents, self.outputPath)
        else:
            with open(self.outputPath + os.sep + self.fasta_file_name, "w", encoding="utf-8") as f:
                f.write(download_contents)
            self.fastaDownloadFinishedSig.emit(self.outputPath)
        # result_handle = Entrez.efetch(
        #     db="nucleotide", rettype="gb",  id=id_array, retmode="text")
        # # with open(self.exportPath + os.sep + "new.gb", "w", encoding="utf-8") as f2:
        # #     f2.write(result_handle.read())
        # self.inputContentSig.emit(
        #     result_handle.read(), []) 
開發者ID:dongzhang0725,項目名稱:PhyloSuite,代碼行數:31,代碼來源:Lg_addFiles.py

示例15: on_toolButton_clicked

# 需要導入模塊: from Bio import Entrez [as 別名]
# 或者: from Bio.Entrez import email [as 別名]
def on_toolButton_clicked(self):
        info = '''To make use of NCBI's E-utilities, NCBI requires you to specify your email address with each request.<br> 
In case of excessive usage of the E-utilities, NCBI will attempt to contact a user at the email address provided before blocking access to the E-utilities.'''
        QMessageBox.information(
            self,
            "Information",
            "<p style='line-height:25px; height:25px'>%s</p>"%info) 
開發者ID:dongzhang0725,項目名稱:PhyloSuite,代碼行數:9,代碼來源:Lg_addFiles.py


注:本文中的Bio.Entrez.email方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。