| Title: | Search and Query CRAN R Packages | 
|---|---|
| Description: | Search CRAN metadata about packages by keyword, popularity, recent activity, package name and more. Uses the 'R-hub' search server, see <https://r-pkg.org> and the CRAN metadata database, that contains information about CRAN packages. Note that this is _not_ a CRAN project. | 
| Authors: | Gábor Csárdi [aut, cre], Maëlle Salmon [aut] (ORCID: <https://orcid.org/0000-0002-2815-0399>), R Consortium [fnd] | 
| Maintainer: | Gábor Csárdi <[email protected]> | 
| License: | MIT + file LICENSE | 
| Version: | 3.1.5.9000 | 
| Built: | 2025-10-05 03:52:54 UTC | 
| Source: | https://github.com/r-hub/pkgsearch | 
See the Elastic documentation for the syntax and features: https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-query-string-query.html
advanced_search( ..., json = NULL, format = c("short", "long"), from = 1, size = 10 )advanced_search( ..., json = NULL, format = c("short", "long"), from = 1, size = 10 )
| ... | Search terms. For named terms, the name specifies the field
to search for. For unnamed ones, the term is taken as is. The
individual terms are combined with the  | 
| json | A character string that contains the query to
send to Elastic. If this is not  | 
| format | Default formatting of the results. short only outputs the name and title of the packages, long also prints the author, last version, full description and URLs. Note that this only affects the default printing, and you can still inspect the full results, even if you specify short here. | 
| from | Where to start listing the results, for pagination. | 
| size | The number of results to list. | 
Search hits.
# All orphaned packages advanced_search(Maintainer = "ORPHANED") # Packages with both Hester and Wickham as authors advanced_search(Author = "Hester", Author = "Wickham") advanced_search("Author: Hester AND Author: Wickham") # Packages with Hester but not Wickham as author advanced_search(Author = "Hester AND NOT Wickham") # Packages with Hester as an Author, and Wickham in any field advanced_search(Author = "Hester", "Wickham") # Packages with Hester as an Author and Wickham nowhere in the metadata advanced_search(Author = "Hester", "NOT Wickham") # Packages for permutation tests and permissive licenses advanced_search("permutation test AND NOT License: GPL OR GNU") # Packages that have a certain field advanced_search("_exists_" = "URL") # Packages that do not have a certain field: advanced_search("NOT _exists_: URL") # The same but as JSON query query <- '{ "query": { "bool": { "must_not": { "exists": { "field": "URL" } } } } }' advanced_search(json = query) # Regular expressions advanced_search(Author = "/Joh?nathan/") # Fuzzy search advanced_search(Author = "Johnathan~1")# All orphaned packages advanced_search(Maintainer = "ORPHANED") # Packages with both Hester and Wickham as authors advanced_search(Author = "Hester", Author = "Wickham") advanced_search("Author: Hester AND Author: Wickham") # Packages with Hester but not Wickham as author advanced_search(Author = "Hester AND NOT Wickham") # Packages with Hester as an Author, and Wickham in any field advanced_search(Author = "Hester", "Wickham") # Packages with Hester as an Author and Wickham nowhere in the metadata advanced_search(Author = "Hester", "NOT Wickham") # Packages for permutation tests and permissive licenses advanced_search("permutation test AND NOT License: GPL OR GNU") # Packages that have a certain field advanced_search("_exists_" = "URL") # Packages that do not have a certain field: advanced_search("NOT _exists_: URL") # The same but as JSON query query <- '{ "query": { "bool": { "must_not": { "exists": { "field": "URL" } } } } }' advanced_search(json = query) # Regular expressions advanced_search(Author = "/Joh?nathan/") # Fuzzy search advanced_search(Author = "Johnathan~1")
List of all CRAN events (new, updated, archived packages)
cran_events(releases = TRUE, archivals = TRUE, limit = 10, from = 1) ## S3 method for class 'cran_event_list' summary(object, ...) ## S3 method for class 'cran_event_list' print(x, ...)cran_events(releases = TRUE, archivals = TRUE, limit = 10, from = 1) ## S3 method for class 'cran_event_list' summary(object, ...) ## S3 method for class 'cran_event_list' print(x, ...)
| releases | Whether to include package releases. | 
| archivals | Whether to include package archivals. | 
| limit | Number of events to list. | 
| from | Where to start the list, for pagination. | 
| object | Object to summarize. | 
| ... | Additional arguments are ignored currently. | 
| x | Object to print. | 
List of events.
cran_events() cran_events(limit = 5, releases = FALSE) cran_events(limit = 5, archivals = FALSE) summary(cran_events(limit = 10))cran_events() cran_events(limit = 5, releases = FALSE) cran_events(limit = 5, archivals = FALSE) summary(cran_events(limit = 10))
List the latest new CRAN packages.
cran_new(from = "last-week", to = "now", last = Inf)cran_new(from = "last-week", to = "now", last = Inf)
| from | Start of the time interval to query. Possible values: 
 | 
| to | End of the time interval to query. It accepts the same kinds
of values as  | 
| last | Integer to limit the number of returned packages. | 
Data frame of package descriptions.
# Last week cran_new("last-week") # Last month cran_new("last-month") # Last 5 days cran_new(from = 5) # From a given date, but at most 10 cran_new(from = "2021-04-06", last = 10) # March of 2021 cran_new(from = "2021-03-01", to = "2021-04-01")# Last week cran_new("last-week") # Last month cran_new("last-month") # Last 5 days cran_new(from = 5) # From a given date, but at most 10 cran_new(from = "2021-04-06", last = 10) # March of 2021 cran_new(from = "2021-03-01", to = "2021-04-01")
Metadata about a CRAN package
cran_package(name, version = NULL)cran_package(name, version = NULL)
| name | Name of the package. | 
| version | The package version to query. If  | 
The package metadata, in a named list.
cran_package("pkgsearch")cran_package("pkgsearch")
Query the history of a package
cran_package_history(package)cran_package_history(package)
| package | Package name. | 
A data frame, with one row per package version.
cran_package_history("igraph")cran_package_history("igraph")
Metadata about multiple CRAN packages
cran_packages(names)cran_packages(names)
| names | Package names. May also contain versions, separated by a
 | 
A data frame of package metadata, one package per row.
# Get metadata about one package cran_packages("rhub") # Get metadata about two packages cran_packages(c("rhub", "testthat")) # Get metadata about two packages at given versions cran_packages(c("[email protected]", "[email protected]", "[email protected]")) # If a version does not exist nothing is returned cran_packages("rhub@notaversion")# Get metadata about one package cran_packages("rhub") # Get metadata about two packages cran_packages(c("rhub", "testthat")) # Get metadata about two packages at given versions cran_packages(c("[email protected]", "[email protected]", "[email protected]")) # If a version does not exist nothing is returned cran_packages("rhub@notaversion")
Last week.
cran_top_downloaded()cran_top_downloaded()
You can use the cranlogs package
to get more flexibility into what is returned.
Data frame of top downloaded packages.
cran_top_downloaded()cran_top_downloaded()
Trending packages are the ones that were downloaded at least 1000 times during last week, and that substantially increased their download counts, compared to the average weekly downloads in the previous 24 weeks. The percentage of increase is also shown in the output.
cran_trending()cran_trending()
Data frame of trending packages.
cran_trending()cran_trending()
pkg_search() starts a new search query, or shows the details of the
previous query, if called without arguments.
ps() is an alias to pkg_search().
more() retrieves that next page of results for the previous query.
pkg_search(query = NULL, format = c("short", "long"), from = 1, size = 10) ps(query = NULL, format = c("short", "long"), from = 1, size = 10) more(format = NULL, size = NULL) ## S3 method for class 'pkg_search_result' summary(object, ...) ## S3 method for class 'pkg_search_result' print(x, ...)pkg_search(query = NULL, format = c("short", "long"), from = 1, size = 10) ps(query = NULL, format = c("short", "long"), from = 1, size = 10) more(format = NULL, size = NULL) ## S3 method for class 'pkg_search_result' summary(object, ...) ## S3 method for class 'pkg_search_result' print(x, ...)
| query | Search query string. If this argument is missing or
 | 
| format | Default formatting of the results. short only outputs the name and title of the packages, long also prints the author, last version, full description and URLs. Note that this only affects the default printing, and you can still inspect the full results, even if you specify short here. | 
| from | Where to start listing the results, for pagination. | 
| size | The number of results to list. | 
| object | Object to summarize. | 
| ... | Additional arguments, ignored currently. | 
| x | Object to print. | 
Note that the search needs a working Internet connection.
A data frame with columns:
score: Score of the hit. See Section Scoring for some details.
package: Package name.
version: Latest package version.
title: Package title.
description: Short package description.
date: Time stamp of the last release.
maintainer_name: Name of the package maintainer.
maintainer_email: Email address of the package maintainer.
revdeps: Number of (strong and weak) reverse dependencies of the
package.
downloads_last_month: Raw number of package downloads last month,
from the RStudio CRAN mirror.
license: Package license.
url: Package URL(s).
bugreports: URL of issue tracker, or email address for bug reports.
# Example ps("survival") # Pagination ps("networks") more() # Details ps("visualization") ps() # See the underlying data frame ps("ropensci") ps()[]# Example ps("survival") # Pagination ps("networks") more() # Details ps("visualization") ps() # See the underlying data frame ps("ropensci") ps()[]
Call this function from RStudio for best results. You can also use it without RStudio, then it will run in the web browser.
pkg_search_addin(query = "", viewer = c("dialog", "browser"))pkg_search_addin(query = "", viewer = c("dialog", "browser"))
| query | Query string to start the addin with. | 
| viewer | Whether to show the addin within RStudio ( | 
The app has:
 A search tab for free text search, very much like the pkg_search()
function.
The list of recently updated packages.
The list of top packages: most downloaded, most depended upon, and trending packages.
Package list by maintainer.
pkg_search_addin()
# Start with a search query
pkg_search_addin("permutation test")