• Stars
    star
    289
  • Rank 143,419 (Top 3 %)
  • Language
  • Created about 8 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

I love the here package. Here's why.

Ode to the here package

TL;DR

  1. Install here.

    install.packages("here")
  2. Use it.

    library(here)
    here("data", "file_i_want.csv")

This works, regardless of where the associated source file lives inside your project. These paths will also “just work” during interactive development, without incessant fiddling with the working directory of your IDE’s R process.

here::here() works like file.path(), but where the path root is implicitly set to “the path to the top-level of my current project”. See The Fine Print for the underlying heuristics. If they don’t suit, use the more powerful package rprojroot directly. Both here and rprojroot are written by Kirill Müller and are available on CRAN.

Admitting you have a problem

If the first line of your #rstats script is setwd("C:\Users\jenny\path\that\only\I\have"), I will come into your lab and SET YOUR COMPUTER ON FIRE.

Mash-up of rage tweets by @jennybc and @tpoi.

Do you:

  • Have setwd() in your scripts? PLEASE STOP DOING THAT.
    • This makes your script very fragile, hard-wired to exactly one time and place. As soon as you rename or move directories, it breaks. Or maybe you get a new computer? Or maybe someone else needs to run your code? We show a very accessible way to go cold turkey and eliminate the setwd() gotcha from your code.
  • Fanny around with working directory alot? During development and/or at run time? YOU CAN STOP DOING THAT TOO.
    • Classic problem presentation: Awkwardness around building paths and/or setting working directory in projects with subdirectories. Especially if you use R Markdown and knitr, which trips up alot of people with its default behavior of “working directory = directory where this file lives”. We show a very accessible way to specify paths in your project’s .R and .Rmd files, regardless of where they live.

Read my blog post “Project-oriented workflow” for more about why setwd() is so problematic and often associated with other awkward workflow problems. Never fear: there are solutions!

Actual demonstration of here::here()

I will let this code run.

What does here think the top-level of current project is? The package displays this on load or, at any time, you can just call here().

library(here)
#> here() starts at /Users/jenny/rrr/here_here
here()
#> [1] "/Users/jenny/rrr/here_here"

Build a path to something in a subdirectory and use it.

here("one", "two", "awesome.txt")
#> [1] "/Users/jenny/rrr/here_here/one/two/awesome.txt"
cat(readLines(here("one", "two", "awesome.txt")))
#> OMG this is so awesome!

Don’t try this at home, folks! But let me set working directory to a subdirectory and prove to you that the same code as above, for getting the path to awesome.txt, still works.

setwd(here("one"))
getwd()
#> [1] "/Users/jenny/rrr/here_here/one"
cat(readLines(here("one", "two", "awesome.txt")))
#> OMG this is so awesome!

The fine print

here::here() figures out the top-level of your current project using some sane heuristics. It looks at working directory, checks a criterion and, if not satisfied, moves up to parent directory and checks again. Lather, rinse, repeat.

Here are the criteria. The order doesn’t really matter because all of them are checked for each directory before moving up to the parent directory:

  • Is a file named .here present?
  • Is this an RStudio Project? Literally, can I find a file named something like foo.Rproj?
  • Is this an R package? Does it have a DESCRIPTION file?
  • Is this a remake project? Does it have a file named remake.yml?
  • Is this a projectile project? Does it have a file named .projectile?
  • Is this a checkout from a version control system? Does it have a directory named .git or .svn? Currently, only Git and Subversion are supported.

If no criteria match, the current working directory will be used as fallback. Use set_here() to create an empty .here file that will stop the search if none of the other criteria apply. dr_here() will attempt to explain why here decided the root location the way it did. See the function reference for more detail.

More Repositories

1

googlesheets

Google Spreadsheets R API
R
786
star
2

happy-git-with-r

Using Git and GitHub with R, Rstudio, and R Markdown
TeX
550
star
3

row-oriented-workflows

Row-oriented workflows in R with the tidyverse
R
406
star
4

gapminder

Excerpt from the Gapminder data, as an R data package and in plain text delimited form
R
273
star
5

ggplot2-tutorial

Teaching materials for the R package ggplot2
R
236
star
6

code-smells-and-feels

Talk on code smells and feels and how to change that via refactoring
R
230
star
7

send-email-with-r

How to send a bunch of email from R
R
205
star
8

r-graph-catalog

All graphs in “Creating More Effective Graphs”, made with R package ggplot2.
R
187
star
9

repurrrsive

Recursive lists to use in teaching and examples, because there is no mtcars for lists.
R
133
star
10

access-r-source

How to get at R source. I am sick of Googling this. I am writing it down this time.
120
star
11

free-photos

Places to find CC0 photos and the like
116
star
12

debugging

Talk about general debugging strategies. How to be less confused and frustrated.
R
112
star
13

purrr-tutorial

Materials for getting to the know the R package purrr
HTML
111
star
14

pkg-dev-tutorial

Package Development tutorial for useR! 2019 Toulouse
R
89
star
15

docker-why

Notes about why an R user would use Docker
57
star
16

scary-excel-stories

Sobering things about Excel
55
star
17

jadd

RStudio addins
R
52
star
18

bingo

Generate Bingo cards with R.
R
48
star
19

sanesheets

A rant about spreadsheets.
47
star
20

githug

Interface to local and remote Git operations
R
47
star
21

how-to-name-files

R
43
star
22

manipulate-xml-with-purrr-dplyr-tidyr

Example of taming XML with nested data frames and purrr
HTML
40
star
23

lego-rstats

Photos that depict R data structures and operations via Lego
R
39
star
24

analyze-github-stuff-with-r

Marshal data from the GitHub API with R
R
38
star
25

2015-06-28_r-summit-talk

Talk at R Summit and Workshop about using R Markdown and GitHub in your workflow
38
star
26

operation-chromebook

Setup notes for the Bryan family Chromebooks
35
star
27

zen-art-workflow

Links and credits for a talk: Zen And The aRt Of Workflow Maintenance
R
35
star
28

2015-02-23_bryan-fields-talk

Talk at Workshop on Visualization for Big Data: Strategies and Principles, Fields Institute http://www.fields.utoronto.ca/programs/scientific/14-15/bigdata/visualization/
33
star
29

2016-06_spreadsheets

Talks given in May and June 2016.
32
star
30

2019-07_useR-toulouse-usethis

Talk about the usethis R package at useR! 2019 Toulouse
R
30
star
31

foofactors

Make Factors Less Aggravating
R
29
star
32

excelgesis

Critical explanation or interpretation of ... Excel spreadsheets
R
26
star
33

lotr

R
26
star
34

2024_raukr-purrr-pkg-dev

Jenny Bryan's instruction at RaukR: Advanced R for Bioinformatics Summer School
R
23
star
35

lotr-tidy

Tidy data lesson using Lord of the Rings data.
23
star
36

regexcite

PACKAGE EXISTS FOR DEMONSTRATION PURPOSES ONLY! Make Regular Expressions More Exciting
R
21
star
37

STAT545A_2013

UBC grad course in data analysis with R
HTML
21
star
38

earl-london-2017-bryan

Jenny Bryan talk at EARL London, 2017 September 12/13/14
21
star
39

2018-09_purrr-latinr

R
20
star
40

scream

Get replies and quotes of a tweet
19
star
41

jeremy-howard-posit-conf-2023

Notebook seen in Jeremy Howard's keynote at posit::conf(2023)
Jupyter Notebook
19
star
42

tidy-eval-context

17
star
43

2015-08_bryan-jsm-stat-data-sci-talk

Bryan talk at JSM 2015 re: are statisticians data scientists
R
17
star
44

stat540_2014

STAT540 Statistical Methods for High Dimensional Biology, January - April 2014
R
16
star
45

happy-git-and-github-for-the-user

Talk: Happy Git and GitHub for the useR
14
star
46

frogs

Data from the Calaveras Jumping Frog Jubilee
R
11
star
47

organization-and-naming

Draft of mini-lectures about file organization and naming.
9
star
48

2018_advent-of-code

R
8
star
49

candy

candy survey data
R
8
star
50

2024-04_netherlands-escience

8
star
51

2014-05-12-ubc

Python
8
star
52

making-messages

7
star
53

yelpr

Call the Yelp API from R ... at this point, just helping a student!
R
6
star
54

bioinformatics.ca-swc-r

Software Carpentry Bootcamp for bioinformatics.ca 2014-05-12
R
6
star
55

appveyorWTF

WTF AppVeyor, WTF?
R
5
star
56

2017_advent-of-code

R
5
star
57

STAT545

UBC grad course in data analysis with R
5
star
58

user2016-git-tutorial

Tutorial for useR! 2016 @ Stanford
4
star
59

jennybryan.org

Personal website of Jenny Bryan
HTML
4
star
60

swcR_duke

R content from Duke Software Carpentry Workshop May 2013.
R
4
star
61

jblibminer

Explore Your R Libraries
R
4
star
62

test-drive-a-package

try an experimental version of an R package without messing with your main R library
3
star
63

babystats

Bit of data on the Bryan babies
R
3
star
64

explore-libraries-seattle-practice

Just practicing!
R
3
star
65

miami-intermediate-r

Instructor repository for intermediate R room, U of Miami, Software Carpentry Boot Camp, January 2014
R
3
star
66

angrybunny

Split a single string
R
2
star
67

symlink-test

R
2
star
68

2021-06_raukr-iteration

R
2
star
69

furry-sniffle

A practice GitHub repo
2
star
70

teengecko

What the Package Does (One Line, Title Case)
R
2
star
71

xyztest

2
star
72

nfl

R
2
star
73

apple

Experimenting using GHA to render bookdown into gh-pages branch
TeX
2
star
74

localetest

What the Package Does (One Line, Title Case)
R
2
star
75

arms-length-render

Usage of rmarkdown::render() when intermediates and outputs don't live with source
R
2
star
76

vanNH

In-house statistics for the Vancouver Nighthawks of Major League Ultimate
HTML
2
star
77

testfun

Toy package with some tests
R
2
star
78

rmd-render-fun

R
2
star
79

cran-data-pkg-licenses

A look at the licenses used by data packages on CRAN
1
star
80

2013-11_sfu

Supporting documents for talk and workshop for SFU Statistics and Actuarial Science
1
star
81

README-as-visual-index

Autogenerate README to give visual index of a figure directory
R
1
star
82

refactor

Make Factors Less Annoying
R
1
star
83

vigilant-tribble

There's only one way to figure out how this works.
1
star
84

happy

I am happy
1
star
85

foofactors2

Happier Life With Factors
R
1
star
86

bellybutton

Data from "A Jungle in There" re: bacterial diversity in the adult human belly button
1
star
87

foofactors3

What the Package Does (One Line, Title Case)
R
1
star
88

2014-01-27-miami

Software Carpentry Bootcamp at the University of Miami
Python
1
star
89

stat545a-2013-hw06_baik-jon

Last homework for STAT545A
CSS
1
star
90

devhelp

What the Package Does (One Line, Title Case)
R
1
star
91

STAT545Assignment6

R
1
star
92

excuse-me-iris

Toy example used in the article "Excuse me, do you have a moment to talk about version control?"
R
1
star
93

googledrive-deployed-token-demo-service

R
1
star
94

fuzzy-peach

R
1
star
95

fluffybunny

What the Package Does (One Line, Title Case)
1
star
96

clouddeployoops

1
star
97

pudgy-pig

just testing some instructions
1
star
98

safecall

C
1
star
99

reimagined-goggles

Demo project created from raukR, OK to delete later
1
star
100

abcd

What the Package Does (One Line, Title Case)
R
1
star