rentrez tutorial


for v1.1.0


The NCBI shares a lot of data. At the time this document was compiled, there were 27.7 million papers in PubMed, including 4.7 million full-text records available in PubMed Central. The NCBI Nucleotide Database (which includes GenBank) has data for 248 million different sequences, and dbSNP describes 1070.2 million different genetic variants. All of these records can be cross-referenced with the 1.3 million species in the NCBI taxonomy or 25.2 thousand disease-associated records in OMIM.

The NCBI makes this data available through a web interface, an FTP server and through a REST API called the Entrez Utilities (Eutils for short). This package provides functions to use that API, allowing users to gather and combine data from multiple NCBI databases in the comfort of an R session or script.

Installation

install.packages("rentrez")

Development version on GitHub

install.packages("devtools")
devtools::install_github("ropensci/rentrez")

Load

library("rentrez")

Getting started with the rentrez

To make the most of all the data the NCBI shares you need to know a little about their databases, the records they contain and the ways you can find those records. The NCBI provides extensive documentation for each of their databases and for the EUtils API that rentrez takes advantage of. There are also some helper functions in rentrez that help users learn their way around the NCBI’s databases.

First, you can use entrez_dbs() to find the list of available databases:

entrez_dbs()
#>  [1] "pubmed"          "protein"         "nuccore"        
#>  [4] "ipg"             "nucleotide"      "nucgss"         
#>  [7] "nucest"          "structure"       "sparcle"        
#> [10] "genome"          "annotinfo"       "assembly"       
#> [13] "bioproject"      "biosample"       "blastdbinfo"    
#> [16] "books"           "cdd"             "clinvar"        
#> [19] "clone"           "gap"             "gapplus"        
#> [22] "grasp"           "dbvar"           "gene"           
#> [25] "gds"             "geoprofiles"     "homologene"     
#> [28] "medgen"          "mesh"            "ncbisearch"     
#> [31] "nlmcatalog"      "omim"            "orgtrack"       
#> [34] "pmc"             "popset"          "probe"          
#> [37] "proteinclusters" "pcassay"         "biosystems"     
#> [40] "pccompound"      "pcsubstance"     "pubmedhealth"   
#> [43] "seqannot"        "snp"             "sra"            
#> [46] "taxonomy"        "biocollections"  "unigene"        
#> [49] "gencoll"         "gtr"

There is a set of functions with names starting entrez_db_ that can be used to gather more information about each of these databases:

Functions that help you learn about NCBI databases

Function name Return
entrez_db_summary() Brief description of what the database is
entrez_db_searchable() Set of search terms that can used with this database
entrez_db_links() Set of databases that might contain linked records

For instance, we can get a description of the somewhat cryptically named database ‘cdd’…

entrez_db_summary("cdd")
#>  DbName: cdd
#>  MenuName: Conserved Domains
#>  Description: Conserved Domain Database
#>  DbBuild: Build170330-1240.1
#>  Count: 56066
#>  LastUpdate: 2017/03/31 16:02

… or find out which search terms can be used with the Sequence Read Archive (SRA) database (which contains raw data from sequencing projects):

entrez_db_searchable("sra")
#> Searchable fields for database 'sra'
#>   ALL 	 All terms from all searchable fields 
#>   UID 	 Unique number assigned to publication 
#>   FILT 	 Limits the records 
#>   ACCN 	 Accession number of sequence 
#>   TITL 	 Words in definition line 
#>   PROP 	 Classification by source qualifiers and molecule type 
#>   WORD 	 Free text associated with record 
#>   ORGN 	 Scientific and common names of organism, and all higher levels of taxonomy 
#>   AUTH 	 Author(s) of publication 
#>   PDAT 	 Date sequence added to GenBank 
#>   MDAT 	 Date of last update 
#>   GPRJ 	 BioProject 
#>   BSPL 	 BioSample 
#>   PLAT 	 Platform 
#>   STRA 	 Strategy 
#>   SRC 	 Source 
#>   SEL 	 Selection 
#>   LAY 	 Layout 
#>   RLEN 	 Percent of aligned reads 
#>   ACS 	 Access is public or controlled 
#>   ALN 	 Percent of aligned reads 
#>   MBS 	 Size in megabases

Just how these ‘helper’ functions might be useful will become clearer once you’ve started using rentrez, so let’s get started.

Very often, the first thing you’ll want to do with rentrez is search a given NCBI database to find records that match some keywords. You can do this using the function entrez_search(). In the simplest case you just need to provide a database name (db) and a search term (term) so let’s search PubMed for articles about the R language:

r_search <- entrez_search(db="pubmed", term="R Language")

The object returned by a search acts like a list, and you can get a summary of its contents by printing it.

r_search
#> Entrez search result with 10421 hits (object contains 20 IDs and no web_history object)
#>  Search term (as translated):  R[All Fields] AND ("programming languages"[MeSH Te ...

There are a few things to note here. First, the NCBI’s server has worked out that we meant R as a programming language, and so included the ‘MeSH’ term term associated with programming languages. We’ll worry about MeSH terms and other special queries later, for now just note that you can use this feature to check that your search term was interpreted in the way you intended. Second, there are many more ‘hits’ for this search than there are unique IDs contained in this object. That’s because the optional argument retmax, which controls the maximum number of returned values has a default value of 20.

The IDs are the most important thing returned here. They allow us to fetch records matching those IDs, gather summary data about them or find cross-referenced records in other databases. We access the IDs as a vector using the $ operator:

r_search$ids
#>  [1] "29036317" "29034090" "29032807" "29030958" "29023637" "28994302"
#>  [7] "28990663" "28989784" "28988220" "28987060" "28984295" "28980887"
#> [13] "28980831" "28979981" "28977332" "28977093" "28975517" "28975282"
#> [19] "28973101" "28969309"

If we want to get more than 20 IDs we can do so by increasing the ret_max argument.

another_r_search <- entrez_search(db="pubmed", term="R Language", retmax=40)
another_r_search
#> Entrez search result with 10421 hits (object contains 40 IDs and no web_history object)
#>  Search term (as translated):  R[All Fields] AND ("programming languages"[MeSH Te ...

If we want to get IDs for all of the thousands of records that match this search, we can use the NCBI’s web history feature described below.

Building search terms

The EUtils API uses a special syntax to build search terms. You can search a database against a specific term using the format query[SEARCH FIELD], and combine multiple such searches using the boolean operators AND, OR and NOT.

For instance, we can find next generation sequence datasets for the (amazing…) ciliate Tetrahymena thermophila by using the organism (‘ORGN’) search field:

entrez_search(db="sra",
              term="Tetrahymena thermophila[ORGN]",
              retmax=0)
#> Entrez search result with 258 hits (object contains 0 IDs and no web_history object)
#>  Search term (as translated):  "Tetrahymena thermophila"[Organism]

We can narrow our focus to only those records that have been added recently (using the colon to specify a range of values):

entrez_search(db="sra",
              term="Tetrahymena thermophila[ORGN] AND 2013:2015[PDAT]",
              retmax=0)
#> Entrez search result with 75 hits (object contains 0 IDs and no web_history object)
#>  Search term (as translated):  "Tetrahymena thermophila"[Organism] AND 2013[PDAT] ...

Or include recent records for either T. thermophila or it’s close relative T. borealis (using parentheses to make ANDs and ORs explicit).

entrez_search(db="sra",
              term="(Tetrahymena thermophila[ORGN] OR Tetrahymena borealis[ORGN]) AND 2013:2015[PDAT]",
              retmax=0)
#> Entrez search result with 75 hits (object contains 0 IDs and no web_history object)
#>  Search term (as translated):  ("Tetrahymena thermophila"[Organism] OR "Tetrahyme ...

The set of search terms available varies between databases. You can get a list of available terms or any given data base with entrez_db_searchable()

entrez_db_searchable("sra")
#> Searchable fields for database 'sra'
#>   ALL 	 All terms from all searchable fields 
#>   UID 	 Unique number assigned to publication 
#>   FILT 	 Limits the records 
#>   ACCN 	 Accession number of sequence 
#>   TITL 	 Words in definition line 
#>   PROP 	 Classification by source qualifiers and molecule type 
#>   WORD 	 Free text associated with record 
#>   ORGN 	 Scientific and common names of organism, and all higher levels of taxonomy 
#>   AUTH 	 Author(s) of publication 
#>   PDAT 	 Date sequence added to GenBank 
#>   MDAT 	 Date of last update 
#>   GPRJ 	 BioProject 
#>   BSPL 	 BioSample 
#>   PLAT 	 Platform 
#>   STRA 	 Strategy 
#>   SRC 	 Source 
#>   SEL 	 Selection 
#>   LAY 	 Layout 
#>   RLEN 	 Percent of aligned reads 
#>   ACS 	 Access is public or controlled 
#>   ALN 	 Percent of aligned reads 
#>   MBS 	 Size in megabases

Precise queries using MeSH terms

In addition to the search terms described above, the NCBI allows searches using Medical Subject Heading (MeSH) terms. These terms create a ‘controlled vocabulary’, and allow users to make very finely controlled queries of databases.

For instance, if you were interested in reviewing studies on how a class of anti-malarial drugs called Folic Acid Antagonists work against Plasmodium vivax (a particular species of malarial parasite), you could use this search:

entrez_search(db   = "pubmed",
              term = "(vivax malaria[MeSH]) AND (folic acid antagonists[MeSH])")
#> Entrez search result with 12 hits (object contains 12 IDs and no web_history object)
#>  Search term (as translated):  "malaria, vivax"[MeSH Terms] AND "folic acid antag ...

The complete set of MeSH terms is available as a database from the NCBI. That means it is possible to download detailed information about each term and find the ways in which terms relate to each other using rentrez. You can search for specific terms with entrez_search(db="mesh", term =...) and learn about the results of your search using the tools described below.

Advanced counting

As you can see above, the object returned by entrez_search() includes the number of records matching a given search. This means you can learn a little about the composition of, or trends in, the records stored in the NCBI’s databases using only the search utility. For instance, let’s track the rise of the scientific buzzword “connectome” in PubMed, programmatically creating search terms for the PDAT field:

search_year <- function(year, term){
    query <- paste(term, "AND (", year, "[PDAT])")
    entrez_search(db="pubmed", term=query, retmax=0)$count
}

year <- 2008:2014
papers <- sapply(year, search_year, term="Connectome", USE.NAMES=FALSE)

plot(year, papers, type='b', main="The Rise of the Connectome")

plot of chunk connectome

One of the strengths of the NCBI databases is the degree to which records of one type are connected to other records within the NCBI or to external data sources. The function entrez_link() allows users to discover these links between records.

To get an idea of the degree to which records in the NCBI are cross-linked we can find all NCBI data associated with a single gene (in this case the Amyloid Beta Precursor gene, the product of which is associated with the plaques that form in the brains of Alzheimer’s Disease patients).

The function entrez_link() can be used to find cross-referenced records. In the most basic case we need to provide an ID (id), the database from which this ID comes (dbfrom) and the name of a database in which to find linked records (db). If we set this last argument to ‘all’ we can find links in multiple databases:

all_the_links <- entrez_link(dbfrom='gene', id=351, db='all')
all_the_links
#> elink object with contents:
#>  $links: IDs for linked records from NCBI
#> 

Just as with entrez_search the returned object behaves like a list, and we can learn a little about its contents by printing it. In the case, all of the information is in links (and there’s a lot of them!):

all_the_links$links
#> elink result with information from 54 databases:
#>  [1] gene_bioconcepts               gene_biosystems               
#>  [3] gene_biosystems_all            gene_clinvar                  
#>  [5] gene_clinvar_specific          gene_dbvar                    
#>  [7] gene_genome                    gene_gtr                      
#>  [9] gene_homologene                gene_medgen_diseases          
#> [11] gene_pcassay_alltarget_list    gene_pcassay_alltarget_summary
#> [13] gene_pcassay_rnai              gene_pcassay_target           
#> [15] gene_probe                     gene_structure                
#> [17] gene_bioproject                gene_books                    
#> [19] gene_cdd                       gene_gene_h3k4me3             
#> [21] gene_gene_neighbors            gene_genereviews              
#> [23] gene_genome2                   gene_geoprofiles              
#> [25] gene_nuccore                   gene_nuccore_mgc              
#> [27] gene_nuccore_pos               gene_nuccore_refseqgene       
#> [29] gene_nuccore_refseqrna         gene_nucest                   
#> [31] gene_nucest_clust              gene_nucleotide               
#> [33] gene_nucleotide_clust          gene_nucleotide_mgc           
#> [35] gene_nucleotide_mgc_url        gene_nucleotide_pos           
#> [37] gene_omim                      gene_pcassay_proteintarget    
#> [39] gene_pccompound                gene_pcsubstance              
#> [41] gene_pmc                       gene_pmc_nucleotide           
#> [43] gene_protein                   gene_protein_refseq           
#> [45] gene_pubmed                    gene_pubmed_citedinomim       
#> [47] gene_pubmed_pmc_nucleotide     gene_pubmed_rif               
#> [49] gene_snp                       gene_snp_geneview             
#> [51] gene_sparcle                   gene_taxonomy                 
#> [53] gene_unigene                   gene_varview

The names of the list elements are in the format [source_database]_[linked_database] and the elements themselves contain a vector of linked-IDs. So, if we want to find open access publications associated with this gene we could get linked records in PubMed Central:

all_the_links$links$gene_pmc[1:10]
#>  [1] "5561919" "5560349" "5559291" "5548265" "5540602" "5434815" "5395029"
#>  [8] "5360245" "5233555" "5104494"

Or if were interested in this gene’s role in diseases we could find links to clinVar:

all_the_links$links$gene_clinvar
#>   [1] "397432" "396808" "396332" "396150" "394309" "391496" "369359"
#>   [8] "339659" "339658" "339657" "339656" "339655" "339654" "339653"
#>  [15] "339652" "339651" "339650" "339649" "339648" "339647" "339646"
#>  [22] "339645" "339644" "339643" "339642" "339641" "339640" "339639"
#>  [29] "339638" "339637" "339636" "339635" "339634" "339633" "339632"
#>  [36] "339631" "339630" "339629" "339628" "339627" "339626" "339625"
#>  [43] "339624" "339623" "339622" "339621" "339620" "339619" "253512"
#>  [50] "253403" "236549" "236548" "236547" "221889" "160886" "155682"
#>  [57] "155309" "155093" "155053" "154360" "154063" "153438" "152839"
#>  [64] "151388" "150018" "149551" "149418" "149160" "149035" "148411"
#>  [71] "148262" "148180" "146125" "145984" "145474" "145468" "145332"
#>  [78] "145107" "144677" "144194" "127268" "98242"  "98241"  "98240" 
#>  [85] "98239"  "98238"  "98237"  "98236"  "98235"  "59247"  "59246" 
#>  [92] "59245"  "59243"  "59226"  "59224"  "59223"  "59222"  "59221" 
#>  [99] "59010"  "59005"  "59004"  "37145"  "32099"  "18106"  "18105" 
#> [106] "18104"  "18103"  "18102"  "18101"  "18100"  "18099"  "18098" 
#> [113] "18097"  "18096"  "18095"  "18094"  "18093"  "18092"  "18091" 
#> [120] "18090"  "18089"  "18088"  "18087"

####Narrowing our focus

If we know beforehand what sort of links we’d like to find , we can to use the db argument to narrow the focus of a call to entrez_link.

For instance, say we are interested in knowing about all of the RNA transcripts associated with the Amyloid Beta Precursor gene in humans. Transcript sequences are stored in the nucleotide database (referred to as nuccore in EUtils), so to find transcripts associated with a given gene we need to set dbfrom=gene and db=nuccore.

nuc_links <- entrez_link(dbfrom='gene', id=351, db='nuccore')
nuc_links
#> elink object with contents:
#>  $links: IDs for linked records from NCBI
#> 
nuc_links$links
#> elink result with information from 5 databases:
#> [1] gene_nuccore            gene_nuccore_mgc        gene_nuccore_pos       
#> [4] gene_nuccore_refseqgene gene_nuccore_refseqrna

The object we get back contains links to the nucleotide database generally, but also to special subsets of that database like refseq. We can take advantage of this narrower set of links to find IDs that match unique transcripts from our gene of interest.

nuc_links$links$gene_nuccore_refseqrna
#>  [1] "324021747" "324021746" "324021739" "324021737" "324021735"
#>  [6] "228008405" "228008404" "228008403" "228008402" "228008401"

We can use these ids in calls to entrez_fetch() or entrez_summary() to learn more about the transcripts they represent.

####External links

In addition to finding data within the NCBI, entrez_link can turn up connections to external databases. Perhaps the most interesting example is finding links to the full text of papers in PubMed. For example, when I wrote this document the first paper linked to Amyloid Beta Precursor had a unique ID of 25500142. We can find links to the full text of that paper with entrez_link by setting the cmd argument to ‘llinks’:

paper_links <- entrez_link(dbfrom="pubmed", id=25500142, cmd="llinks")
paper_links
#> elink object with contents:
#>  $linkouts: links to external websites

Each element of the linkouts object contains information about an external source of data on this paper:

paper_links$linkouts
#> $ID_25500142
#> $ID_25500142[[1]]
#> Linkout from Elsevier Science 
#>  $Url: https://linkinghub.elsevie ...
#> 
#> $ID_25500142[[2]]
#> Linkout from Europe PubMed Central 
#>  $Url: http://europepmc.org/abstr ...
#> 
#> $ID_25500142[[3]]
#> Linkout from Ovid Technologies, Inc. 
#>  $Url: http://ovidsp.ovid.com/ovi ...
#> 
#> $ID_25500142[[4]]
#> Linkout from PubMed Central 
#>  $Url: https://www.ncbi.nlm.nih.g ...
#> 
#> $ID_25500142[[5]]
#> Linkout from PubMed Central Canada 
#>  $Url: http://pubmedcentralcanada ...
#> 
#> $ID_25500142[[6]]
#> Linkout from MedlinePlus Health Information 
#>  $Url: https://medlineplus.gov/al ...
#> 
#> $ID_25500142[[7]]
#> Linkout from Mouse Genome Informatics (MGI) 
#>  $Url: http://www.informatics.jax ...

Each of those linkout objects contains quite a lot of information, but the URL is probably the most useful. For that reason, rentrez provides the function linkout_urls to make extracting just the URL simple:

linkout_urls(paper_links)
#> $ID_25500142
#> [1] "https://linkinghub.elsevier.com/retrieve/pii/S0014-4886(14)00393-8"     
#> [2] "http://europepmc.org/abstract/MED/25500142"                             
#> [3] "http://ovidsp.ovid.com/ovidweb.cgi?T=JS&PAGE=linkout&SEARCH=25500142.ui"
#> [4] "https://www.ncbi.nlm.nih.gov/pmc/articles/pmid/25500142/"               
#> [5] "http://pubmedcentralcanada.ca/pmcc/articles/pmid/25500142"              
#> [6] "https://medlineplus.gov/alzheimersdisease.html"                         
#> [7] "http://www.informatics.jax.org/reference/25500142"

The full list of options for the cmd argument are given in in-line documentation (?entrez_link). If you are interested in finding full text records for a large number of articles checkout the package fulltext which makes use of multiple sources (including the NCBI) to discover the full text articles.

####Using more than one ID

It is possible to pass more than one ID to entrez_link(). By default, doing so will give you a single elink object containing the complete set of links for all of the IDs that you specified. So, if you were looking for protein IDs related to specific genes you could do:

all_links_together  <- entrez_link(db="protein", dbfrom="gene", id=c("93100", "223646"))
all_links_together
#> elink object with contents:
#>  $links: IDs for linked records from NCBI
#> 
all_links_together$links$gene_protein
#>  [1] "1034662002" "1034662000" "1034661998" "1034661996" "1034661994"
#>  [6] "1034661992" "558472750"  "545685826"  "194394158"  "166221824" 
#> [11] "154936864"  "148697547"  "148697546"  "122346659"  "119602646" 
#> [16] "119602645"  "119602644"  "119602643"  "119602642"  "81899807"  
#> [21] "74215266"   "74186774"   "37787317"   "37787309"   "37787307"  
#> [26] "37787305"   "37589273"   "33991172"   "31982089"   "26339824"  
#> [31] "26329351"   "21619615"   "10834676"

Although this behaviour might sometimes be useful, it means we’ve lost track of which protein ID is linked to which gene ID. To retain that information we can set by_id to TRUE. This gives us a list of elink objects, each once containing links from a single gene ID:

all_links_sep  <- entrez_link(db="protein", dbfrom="gene", id=c("93100", "223646"), by_id=TRUE)
all_links_sep
#> List of 2 elink objects,each containing
#>   $links: IDs for linked records from NCBI
#> 
lapply(all_links_sep, function(x) x$links$gene_protein)
#> [[1]]
#>  [1] "1034662002" "1034662000" "1034661998" "1034661996" "1034661994"
#>  [6] "1034661992" "558472750"  "545685826"  "194394158"  "166221824" 
#> [11] "154936864"  "122346659"  "119602646"  "119602645"  "119602644" 
#> [16] "119602643"  "119602642"  "37787309"   "37787307"   "37787305"  
#> [21] "33991172"   "21619615"   "10834676"  
#> 
#> [[2]]
#>  [1] "148697547" "148697546" "81899807"  "74215266"  "74186774" 
#>  [6] "37787317"  "37589273"  "31982089"  "26339824"  "26329351"

Getting summary data: entrez_summary()

Having found the unique IDs for some records via entrez_search or entrez_link(), you are probably going to want to learn something about them. The Eutils API has two ways to get information about a record. entrez_fetch() returns ‘full’ records in varying formats and entrez_summary() returns less information about each record, but in relatively simple format. Very often the summary records have the information you are after, so rentrez provides functions to parse and summarise summary records.

####The summary record

entrez_summary() takes a vector of unique IDs for the samples you want to get summary information from. Let’s start by finding out something about the paper describing Taxize, using its PubMed ID:

taxize_summ <- entrez_summary(db="pubmed", id=24555091)
taxize_summ
#> esummary result with 42 items:
#>  [1] uid               pubdate           epubdate         
#>  [4] source            authors           lastauthor       
#>  [7] title             sorttitle         volume           
#> [10] issue             pages             lang             
#> [13] nlmuniqueid       issn              essn             
#> [16] pubtype           recordstatus      pubstatus        
#> [19] articleids        history           references       
#> [22] attributes        pmcrefcount       fulljournalname  
#> [25] elocationid       doctype           srccontriblist   
#> [28] booktitle         medium            edition          
#> [31] publisherlocation publishername     srcdate          
#> [34] reportnumber      availablefromurl  locationlabel    
#> [37] doccontriblist    docdate           bookname         
#> [40] chapter           sortpubdate       sortfirstauthor

Once again, the object returned by entrez_summary behaves like a list, so you can extract elements using $. For instance, we could convert our PubMed ID to another article identifier…

taxize_summ$articleids
#>       idtype idtypen                           value
#> 1     pubmed       1                        24555091
#> 2        doi       3 10.12688/f1000research.2-191.v2
#> 3        pmc       8                      PMC3901538
#> 4        rid       8                        24563765
#> 5        eid       8                        24555091
#> 6    version       8                               2
#> 7 version-id       8                               2
#> 8      pmcid       5             pmc-id: PMC3901538;

…or see how many times the article has been cited in PubMed Central papers

taxize_summ$pmcrefcount
#> [1] 13

####Dealing with many records

If you give entrez_summary() a vector with more than one ID you’ll get a list of summary records back. Let’s get those Plasmodium vivax papers we found in the entrez_search() section back, and fetch some summary data on each paper:

vivax_search <- entrez_search(db = "pubmed",
                              term = "(vivax malaria[MeSH]) AND (folic acid antagonists[MeSH])")
multi_summs <- entrez_summary(db="pubmed", id=vivax_search$ids)

rentrez provides a helper function, extract_from_esummary() that takes one or more elements from every summary record in one of these lists. Here it is working with one…

extract_from_esummary(multi_summs, "fulljournalname")
#>                                                                                                                 24861816 
#> "Infection, genetics and evolution : journal of molecular epidemiology and evolutionary genetics in infectious diseases" 
#>                                                                                                                 24145518 
#>                                                                                  "Antimicrobial agents and chemotherapy" 
#>                                                                                                                 24007534 
#>                                                                                                        "Malaria journal" 
#>                                                                                                                 23230341 
#>                                                                                     "The Korean journal of parasitology" 
#>                                                                                                                 23043980 
#>                                                                                              "Experimental parasitology" 
#>                                                                                                                 20810806 
#>                                                                  "The American journal of tropical medicine and hygiene" 
#>                                                                                                                 20412783 
#>                                                                                                           "Acta tropica" 
#>                                                                                                                 19597012 
#>                                                                                          "Clinical microbiology reviews" 
#>                                                                                                                 17556611 
#>                                                                  "The American journal of tropical medicine and hygiene" 
#>                                                                                                                 17519409 
#>                                                                                                                   "JAMA" 
#>                                                                                                                 17368986 
#>                                                                                                 "Trends in parasitology" 
#>                                                                                                                 12374849 
#>                                        "Proceedings of the National Academy of Sciences of the United States of America"

… and several elements:

date_and_cite <- extract_from_esummary(multi_summs, c("pubdate", "pmcrefcount",  "title"))
knitr::kable(head(t(date_and_cite)), row.names=FALSE)
pubdate pmcrefcount title
2014 Aug Prevalence of mutations in the antifolates resistance-associated genes (dhfr and dhps) in Plasmodium vivax parasites from Eastern and Central Sudan.
2014 5 Prevalence of polymorphisms in antifolate drug resistance molecular marker genes pvdhfr and pvdhps in clinical isolates of Plasmodium vivax from Kolkata, India.
2013 Sep 5 2 Prevalence and patterns of antifolate and chloroquine drug resistance markers in Plasmodium vivax across Pakistan.
2012 Dec 13 Prevalence of drug resistance-associated gene mutations in Plasmodium vivax in Central China.
2012 Dec 7 Novel mutations in the antifolate drug resistance marker genes among Plasmodium vivax isolates exhibiting severe manifestations.
2010 Sep 17 Mutations in the antifolate-resistance-associated genes dihydrofolate reductase and dihydropteroate synthase in Plasmodium vivax isolates from malaria-endemic countries.

###Using NCBI’s Web History features

When you are dealing with very large queries it can be time consuming to pass long vectors of unique IDs to and from the NCBI. To avoid this problem, the NCBI provides a feature called “web history” which allows users to store IDs on the NCBI servers then refer to them in future calls.

####Post a set of IDs to the NCBI for later use: entrez_post()

If you have a list of many NCBI IDs that you want to use later on, you can post them to the NCBI’s severs. In order to provide a brief example, I’m going to post just one ID, the omim identifier for asthma:

upload <- entrez_post(db="omim", id=600807)
upload
#> Web history object (QueryKey = 1, WebEnv = NCID_1_31817...)

The NCBI sends you back some information you can use to refer to the posted IDs. In rentrez, that information is represented as a web_history object.

####Get a web_history object from entrez_search or entrez_link()

In addition to directly uploading IDs to the NCBI, you can use the web history features with entrez_search and entrez_link. For instance, imagine you wanted to find all of the sequences of the widely-studied gene COI from all snails (which are members of the taxonomic group Gastropoda):

entrez_search(db="nuccore", term="COI[Gene] AND Gastropoda[ORGN]")
#> Entrez search result with 70941 hits (object contains 20 IDs and no web_history object)
#>  Search term (as translated):  COI[Gene] AND "Gastropoda"[Organism]

That’s a lot of sequences! If you really wanted to download all of these it would be a good idea to save all those IDs to the server by setting use_history to TRUE (note you now get a web_history object along with your normal search result):

snail_coi <- entrez_search(db="nuccore", term="COI[Gene] AND Gastropoda[ORGN]", use_history=TRUE)
snail_coi
#> Entrez search result with 70941 hits (object contains 20 IDs and a web_history object)
#>  Search term (as translated):  COI[Gene] AND "Gastropoda"[Organism]
snail_coi$web_history
#> Web history object (QueryKey = 1, WebEnv = NCID_1_31817...)

Similarity, entrez_link() can return web_history objects by using the cmd neighbor_history. Let’s find genetic variants (from the clinvar database) associated with asthma (using the same OMIM ID we identified earlier):

asthma_clinvar <- entrez_link(dbfrom="omim", db="clinvar", cmd="neighbor_history", id=600807)
asthma_clinvar$web_histories
#> $omim_clinvar
#> Web history object (QueryKey = 1, WebEnv = NCID_1_31886...)

As you can see, instead of returning lists of IDs for each linked database (as it would be default), entrez_link() now returns a list of web_histories.

####Use a web_history object

Once you have those IDs stored on the NCBI’s servers, you are going to want to do something with them. The functions entrez_fetch() entrez_summary() and entrez_link() can all use web_history objects in exactly the same way they use IDs.

So, we could repeat the last example (finding variants linked to asthma), but this time using the ID we uploaded earlier

asthma_variants <- entrez_link(dbfrom="omim", db="clinvar", cmd="neighbor_history", web_history=upload)
asthma_variants
#> elink object with contents:
#>  $web_histories: Objects containing web history information

… if we want to get some genetic information about these variants we need to map our clinvar IDs to SNP IDs:

snp_links <- entrez_link(dbfrom="clinvar", db="snp",
                         web_history=asthma_variants$web_histories$omim_clinvar,
                         cmd="neighbor_history")
snp_summ <- entrez_summary(db="snp", web_history=snp_links$web_histories$clinvar_snp)
knitr::kable(extract_from_esummary(snp_summ, c("chr", "fxn_class", "global_maf")))
41364547 11558538 20541
chr 11 2 5
fxn_class intron-variant,utr-variant-5-prime intron-variant,missense,nc-transcript-variant,reference,utr-variant-5-prime missense,reference
global_maf A=0.0036/18 T=0.0595/298 A=0.2700/1352

If you really wanted to you could also use web_history objects to download all those thousands of COI sequences. When downloading large sets of data, it is a good idea to take advantage of the arguments retmax and restart to split the request up into smaller chunks. For instance, we could get the first 200 sequences in 50-sequence chunks:

(note: this code block is not executed as part of the vignette to save time and bandwidth):

for( seq_start in seq(1,200,50)){
    recs <- entrez_fetch(db="nuccore", web_history=snail_coi$web_history,
                         rettype="fasta", retmax=50, retstart=seq_start)
    cat(recs, file="snail_coi.fasta", append=TRUE)
    cat(seq_start+49, "sequences downloaded\r")
}

Citing

To cite rentrez in publications use:


David Winter (2017). rentrez: Entrez in R. R package version 1.1.0. https://CRAN.R-project.org/package=rentrez

License and bugs