Reputation:
I use an out-of-the-box Anaconda installation to work with Python. Now I have read that it is possible to also "include" the R world within this installation and to use the IR kernel within the Jupyter/Ipython notebook.
I found the command to install a number of famous R packages: conda install -c r r-essentials
My beginner's question:
How do I install R packages that are not included in the R-essential package? For example R packages that are available on CRAN. "pip" works only for PyPI Python packages, doesn't it?
Upvotes: 75
Views: 108686
Reputation: 41275
For me the comment here worked, which means using conda install -c r r-<package_name>
. For example I wanted to install the httr2
package which is not a r-essential. At first I tried this:
conda install httr2
Channels:
- defaults
Platform: linux-64
Collecting package metadata (repodata.json): done
Solving environment: failed
PackagesNotFoundError: The following packages are not available from current channels:
- httr2
Current channels:
- defaults
To search for alternate channels that may provide the conda package you're
looking for, navigate to
https://anaconda.org
and use the search bar at the top of the page.
This doesn't work so I used the command I mentioned at the top conda install -c r r-httr2
like this:
conda install -c r r-httr2
Channels:
- r
- defaults
Platform: linux-64
Collecting package metadata (repodata.json): done
Solving environment: done
## Package Plan ##
environment location: /opt/miniconda3/envs/r_env
added / updated specs:
- r-httr2
The following packages will be downloaded:
package | build
---------------------------|-----------------
r-httr2-0.2.3 | r43h6115d3f_0 371 KB
------------------------------------------------------------
Total: 371 KB
The following NEW packages will be INSTALLED:
r-httr2 pkgs/r/noarch::r-httr2-0.2.3-r43h6115d3f_0
Proceed ([y]/n)? y
Downloading and Extracting Packages:
Preparing transaction: done
Verifying transaction: done
Executing transaction: done
This worked perfectly!
Upvotes: 0
Reputation: 76750
Disclosure: Though not the case when I first answered this, I am now part of the Conda Forge R team. However, this is volunteer work - I receive no compensation for my work there nor whether you follow the advice in this answer.
Five years out from the original question, I'd assert that a more contemporary solution would simply be: use Conda Forge. The Conda Forge channel not only provides broader coverage of CRAN, but also has a simple procedure and great turnaround time (typically under 24 hours) for adding a missing CRAN package to the channel.
I'd recommend using Conda Forge for the full stack, and use a dedicated environment for each R version you require.
conda create -n r41 -c conda-forge r-base=4.1 r-irkernel ...
where ...
is whatever additional packages you require (like r-tidyverse
). The r-irkernel
package is optional, but included here because OP mentions using R in Jupyter.
If your environment with Jupyter (which should be in a separate environment) also has nb_conda_kernels
installed, then this environment will automatically be discovered by Jupyter.
Generally, all R packages on CRAN have an r-
prefixed to the package name on Conda Forge, and the package name is converted to lowercase. So, if your package of interest is PkgName
, first try
conda install -n r41 -c conda-forge r-pkgname
If the package is not available, then proceed to either add it or request it.
There is a helpful script collection, called conda_r_skeleton_helper for creating new Conda Forge recipes for CRAN packages. There are clear directions in the README.
In broad strokes, one will
conda_r_skeleton_helper
repositorypackages.txt
file to include r-pkgname
conda-forge/staged-recipes
stage-recipes/recipes
folderThis takes maybe ~15 mins of work. Once submitted, most packages take under 24 hours to get accepted, feedstocked, and deployed to the Conda Forge channel. Once the feedstock is up and running, the Conda Forge infrastructure uses a bot to auto-detect version updates, generate new pull requests, and even auto-merge Pull Requests that successfully build. That is, maintainers have a very minimal workload, and if there are issues, a team is available to help out.
Personally, I have all this scripted (see scripts). I have a copy of these scripts in the root of a local copy of my staged-recipes
fork. From a shell, I run:
sh new-cran-pkg.sh r-foo
and it:
staged-recipes
main branch to upstream (conda-forge
).r-foo
.conda_r_skeleton_helper
for the package (here r-foo
).I then just have to visit GitHub to set up the Pull Request. Takes less than a minute.
If you have issues with submitting a recipe or updating an existing one, please ping me in a GitHub Issue or Pull Request (@mfansler
).
For users uncomfortable with creating and maintaining a Conda Forge build, packages can be requested on Conda Forge's staged-recipes
repository by filing a new Issue. There is a template for Package Request, that includes some information fields to be filled in.
Upvotes: 6
Reputation: 150
What worked for me is install.packages("package_name", type="binary")
.
None of the other answers have worked.
Upvotes: 1
Reputation: 261
To install other R Packages on Jupyter beyond R-essentials
install.packages('readr', repos='http://cran.us.r-project.org')
One issue is that the specific repository is the US.R-Project
(as below). I tried others and it did not work.
N.B. Replace readr
with any desired package name to install.
Upvotes: 26
Reputation: 11
Someone suggested a not so elegant way around it, but actually it doesn't matter as long as it works fine.
install.packages('package','/Users/yourusernamehere/anaconda/lib/R/library')
I spent almost an entire morning looking for an answer to this problem. I was able to install the libraries on RStudio but not on Jupyter Notebook (they have different versions of R) The above solution "almost" worked, it's just that I found the Jupyter Notebook was trying to install in a different directory, and it will report what directory. So I only changed that and it worked as a charm... thanks to Dninhos
Upvotes: 1
Reputation: 5463
To install a CRAN package from the command line:
R --slave -e "install.packages('missing-package', repos='http://cran.us.r-project.org')"
Upvotes: 6
Reputation: 93
Adding it here so other beginners already working with Jupyter notebooks with Python and interested in using it with R: additional packages available for Anaconda can be installed via terminal using the same command used to instal the essential packages.
Install r-essentials
conda install -c r r-essentials
Install microbenchmark (infrastructure to accurately measure and compare the execution time of R expressions)
conda install -c r r-microbenchmark
Upvotes: 5
Reputation:
Now I have found the documentation:
This is the documentation that explains how to generate R packages that are only available in the CRAN repository: https://www.continuum.io/content/conda-data-science
Go to the section "Building a conda R package".
(Hint: As long as the R package is available under anaconda.org use this resource. See here: https://www.continuum.io/blog/developer/jupyter-and-conda-r)
alistaire's answer is another possibility to add R packages:
If you install packages from inside of R via the regular install.packages
(from CRAN mirrors), or devtools::install_github
(from GitHub), they work fine. @alistaire
How to do this: Open your (independent) R installation, then run the following command:
install.packages("png", "/home/user/anaconda3/lib/R/library")
to add new package to the correct R library used by Jupyter, otherwise the package will be installed in /home/user/R/i686-pc-linux-gnu-library/3.2/png/libs mentioned in .libPaths() .
Upvotes: 42
Reputation: 2908
Here's a conda-centric answer. It builds on Frank's answer and the continuum website: https://www.continuum.io/content/conda-data-science with a bit more detail.
Some packages not available in r-essentials are still available on conda channels, in that case, it's simple:
conda config --add channels r
conda install r-readxl
If you need to build a package and install using conda:
conda skeleton cran r-xgboost
conda build r-xgboost
conda install --use-local r-xgboost
that last line is absent in the continuum website because they assume it gets published to anaconda repository first. Without it, nothing will be put in the envs/ directory and the package won't be accessible to commandline R or Jupyter.
On a mac, I found it important to install the Clang compiler for package builds:
conda install clangxx_oxs-64
Upvotes: 21
Reputation: 21
Install rpy2 with conda and add following line in your Jupyter notebook.
%load_ext rpy2.ipython
In next chunks, you can simply run any r code by specifying %R
Below is my favorite method to install and/or load r package
%R if (!require("pacman")) install.packages("pacman")
%R pacman::p_load(dplyr, data.table, package3, package4)
p_load argument will install + load the package if it's not in your lib else it will simply load it.
Upvotes: 2
Reputation: 639
I found an easy workaround. I suppose that you have an RStudio IDE for you R. It is weird to use RStudio for that, but I tried straight from R in my terminal and it didn't work. So, in RStudio console, just do the usual adding the path to your anaconda directory (in OSX,'/Users/yourusernamehere/anaconda/lib/R/library')
So, for example,
install.packages('package','/Users/yourusernamehere/anaconda/lib/R/library')
I feel ashamed to post such a non-fancy answer, but that is the only one that worked for me.
Upvotes: 15
Reputation: 7554
I had a problem when trying to install package from github using install_github("user/package")
in conda with r-essentials. Errors were multiple and not descriptive.
Was able to resolve a problem using these steps:
library(devtools)
install('/path/to/unzipped-package')
install.packages('missing-package', repos='http://cran.us.r-project.org')
for all dependanciesinstall('/path/to/unzipped-package')
again. Now it should work!Upvotes: 3