R/spacy_langmodel_functions.R

Defines functions spacy_download_langmodel spacy_download_langmodel_virtualenv

Documented in spacy_download_langmodel spacy_download_langmodel_virtualenv

#' Install a language model in a conda or virtual environment
#' 
#' Installs one or more language models in a conda or virtualenv Python virtual
#' environment as installed by \code{\link{spacy_install}}.
#' @param envname name of the virtual environment
#' @param conda Path to conda executable.  Default \code{"auto"} which
#'   automatically finds the path.
#' @param model name of the language model to be installed.  A list of available
#'   language models and their names is available from the
#'   \href{https://spacy.io/usage/models}{spaCy language models} page.
#' @export
spacy_download_langmodel <- function(model = "en",
                                     envname = "spacy_condaenv",
                                     conda = "auto") {
    message(sprintf("Installing model \"%s\"\n", model))
    # resolve conda binary
    conda <- reticulate::conda_binary(conda)

    condaenv_bin <- function(bin) path.expand(file.path(dirname(conda), bin))
    cmd <- sprintf("%s%s %s && python -m spacy download %s%s",
                   ifelse(is_windows(), "", ifelse(is_osx(), "source ", "/bin/bash -c \"source ")),
                   shQuote(path.expand(condaenv_bin("activate"))),
                   envname,
                   model,
                   ifelse(is_windows(), "", ifelse(is_osx(), "", "\"")))
    result <- system(cmd)

    # check for errors
    if (result != 0L) {
        stop("Error ", result, " occurred installing packages into conda environment ",
             envname, call. = FALSE)
    }
    message(sprintf("Language model \"%s\" is successfully installed\n", model))
    invisible(NULL)
}


#' @rdname spacy_download_langmodel
#' @param virtualenv_root path to the virtualenv environment to install spaCy
#'   language model. If \code{NULL}, the default path \code{"~/.virtualenvs"}
#'   will be used.
#' @export
spacy_download_langmodel_virtualenv <- function(model = "en",
                                                envname = "spacy_virtualenv",
                                                virtualenv_root = NULL) {
    message(sprintf("installing model \"%s\"\n", model))
    if (is.null(virtualenv_root)) {
        virtualenv_root <- "~/.virtualenvs"
    }
    virtualenv_bin <- function(bin) path.expand(file.path(virtualenv_path, "bin", bin))

    # create virtualenv if necessary
    virtualenv_path <- file.path(virtualenv_root, "spacy_virtualenv")

    if (!file.exists(virtualenv_path) || !file.exists(virtualenv_bin("activate"))) {
        stop("The virtual environemnt ", virtualenv_path, " does not exist\n")
    }

    cmd <- sprintf("%s%s && python -m spacy download %s%s",
                   ifelse(is_windows(), "", ifelse(is_osx(), "source ", "/bin/bash -c \"source ")),
                   shQuote(path.expand(virtualenv_bin("activate"))),
                   model,
                   ifelse(is_windows(), "", ifelse(is_osx(), "", "\"")))
    result <- system(cmd)

    # check for errors
    if (result != 0L) {
        stop("Error ", result, " occurred installing packages into virtual environment ",
             envname, call. = FALSE)
    }
    message(sprintf("Language model \"%s\" is successfully installed\n", model))

    invisible(NULL)
}

Try the spacyr package in your browser

Any scripts or data that you put into this service are public.

spacyr documentation built on March 26, 2020, 5:25 p.m.