inst/doc/common.R

## ---- include = FALSE---------------------------------------------------------
knitr::opts_chunk$set(
  collapse = TRUE,
  comment = "#>"
)

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Variable names passed to subset are quoted
#  dat <- mtcars[1:10 , c("mpg", "cyl", "disp")]
#  
#  # View results
#  dat
#                     mpg cyl  disp
#  Mazda RX4         21.0   6 160.0
#  Mazda RX4 Wag     21.0   6 160.0
#  Datsun 710        22.8   4 108.0
#  Hornet 4 Drive    21.4   6 258.0
#  Hornet Sportabout 18.7   8 360.0
#  Valiant           18.1   6 225.0
#  Duster 360        14.3   8 360.0
#  Merc 240D         24.4   4 146.7
#  Merc 230          22.8   4 140.8
#  Merc 280          19.2   6 167.6

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # No quotes on "cyl" using subset() function
#  dt <- subset(dat, cyl == 4)
#  
#  # View results
#  dt
#  #             mpg cyl  disp
#  # Datsun 710 22.8   4 108.0
#  # Merc 240D  24.4   4 146.7
#  # Merc 230   22.8   4 140.8

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Create a vector of unquoted names
#  v1 <- v(mpg, cyl, disp)
#  
#  # Result is a quoted vector
#  v1
#  # [1] "mpg"  "cyl"  "disp"
#  
#  # Variable names not quoted
#  dat2 <- mtcars[1:10, v(mpg, cyl, disp)]
#  
#  # Works as expected
#  dat2
#  #                    mpg cyl  disp
#  # Mazda RX4         21.0   6 160.0
#  # Mazda RX4 Wag     21.0   6 160.0
#  # Datsun 710        22.8   4 108.0
#  # Hornet 4 Drive    21.4   6 258.0
#  # Hornet Sportabout 18.7   8 360.0
#  # Valiant           18.1   6 225.0
#  # Duster 360        14.3   8 360.0
#  # Merc 240D         24.4   4 146.7
#  # Merc 230          22.8   4 140.8
#  # Merc 280          19.2   6 167.6
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare data
#  dat <- mtcars[1:10, 1:3]
#  
#  # Get sort order
#  ord <- do.call('order', dat[ ,c("cyl", "mpg")])
#  
#  # Sort data
#  dat[ord, ]
#  #                    mpg cyl  disp
#  # Datsun 710        22.8   4 108.0
#  # Merc 230          22.8   4 140.8
#  # Merc 240D         24.4   4 146.7
#  # Valiant           18.1   6 225.0
#  # Merc 280          19.2   6 167.6
#  # Mazda RX4         21.0   6 160.0
#  # Mazda RX4 Wag     21.0   6 160.0
#  # Hornet 4 Drive    21.4   6 258.0
#  # Duster 360        14.3   8 360.0
#  # Hornet Sportabout 18.7   8 360.0

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Sort by cyl then mpg
#  dat1 <- sort(dat, by = v(cyl, mpg))
#  dat1
#  #                    mpg cyl  disp
#  # Datsun 710        22.8   4 108.0
#  # Merc 230          22.8   4 140.8
#  # Merc 240D         24.4   4 146.7
#  # Valiant           18.1   6 225.0
#  # Merc 280          19.2   6 167.6
#  # Mazda RX4         21.0   6 160.0
#  # Mazda RX4 Wag     21.0   6 160.0
#  # Hornet 4 Drive    21.4   6 258.0
#  # Duster 360        14.3   8 360.0
#  # Hornet Sportabout 18.7   8 360.0
#  
#  # Sort by cyl descending then mpg ascending
#  dat2 <- sort(dat, by = v(cyl, mpg),
#               ascending = c(FALSE, TRUE))
#  dat2
#  #                    mpg cyl  disp
#  # Duster 360        14.3   8 360.0
#  # Hornet Sportabout 18.7   8 360.0
#  # Valiant           18.1   6 225.0
#  # Merc 280          19.2   6 167.6
#  # Mazda RX4         21.0   6 160.0
#  # Mazda RX4 Wag     21.0   6 160.0
#  # Hornet 4 Drive    21.4   6 258.0
#  # Datsun 710        22.8   4 108.0
#  # Merc 230          22.8   4 140.8
#  # Merc 240D         24.4   4 146.7
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare data
#  dat <- mtcars[1:10, 1:3]
#  
#  # Assign labels
#  attr(dat$mpg, "label") <- "Miles Per Gallon"
#  attr(dat$cyl, "label") <- "Cylinders"
#  attr(dat$disp, "label") <- "Displacement"
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare data
#  dat <- mtcars[1:10, 1:3]
#  
#  # Assign labels
#  labels(dat) <- list(mpg = "Miles Per Gallon",
#                      cyl = "Cylinders",
#                      disp = "Displacement")
#  
#  # View label attributes
#  labels(dat)
#  # $mpg
#  # [1] "Miles Per Gallon"
#  #
#  # $cyl
#  # [1] "Cylinders"
#  #
#  # $disp
#  # [1] "Displacement"

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Concatenation using paste0() function
#  paste0("There are ", nrow(mtcars), " rows in the mtcars data frame")
#  # [1] "There are 32 rows in the mtcars data frame"
#  
#  # Concatenation using %p% operator
#  "There are " %p% nrow(mtcars) %p% " rows in the mtcars data frame"
#  # [1] "There are 32 rows in the mtcars data frame"
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  
#  # Comparing of NULLs and NA
#  NULL %eq% NULL        # TRUE
#  NULL %eq% NA          # FALSE
#  NA %eq% NA            # TRUE
#  1 %eq% NULL           # FALSE
#  1 %eq% NA             # FALSE
#  
#  # Comparing of atomic values
#  1 %eq% 1              # TRUE
#  "one" %eq% "one"      # TRUE
#  1 %eq% "one"          # FALSE
#  1 %eq% Sys.Date()     # FALSE
#  
#  # Comparing of vectors
#  v1 <- c("A", "B", "C")
#  v2 <- c("A", "B", "C", "D")
#  v1 %eq% v1            # TRUE
#  v1 %eq% v2            # FALSE
#  
#  # Comparing of data frames
#  mtcars %eq% mtcars    # TRUE
#  mtcars %eq% iris      # FALSE
#  iris %eq% iris[1:50,] # FALSE
#  
#  # Mixing it up
#  mtcars %eq% NULL      # FALSE
#  v1 %eq% NA            # FALSE
#  1 %eq% v1             # FALSE

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Get current path
#  pth <- Sys.path()
#  
#  # View path
#  pth
#  # [1] "C:/packages/common/vignettes/common.Rmd"

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare sample vector
#  v1 <- seq(0.5,9.5,by=1)
#  v1
#  # [1] 0.5 1.5 2.5 3.5 4.5 5.5 6.5 7.5 8.5 9.5
#  
#  # Base R round function
#  r1 <- round(v1)
#  
#  # Rounds to nearest even
#  r1
#  # [1]  0  2  2  4  4  6  6  8  8 10
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Round up function
#  r2 <- roundup(v1)
#  
#  # Rounds 5 up
#  r2
#  # [1]  1  2  3  4  5  6  7  8  9 10
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Negate original vector
#  v2 <- -v1
#  v2
#  # [1] -0.5 -1.5 -2.5 -3.5 -4.5 -5.5 -6.5 -7.5 -8.5 -9.5
#  
#  # Rounding negative values
#  r3 <- roundup(v2)
#  
#  # Rounds away from zero
#  r3
#  # [1]  -1  -2  -3  -4  -5  -6  -7  -8  -9 -10

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Look for a file named "globals.R"
#  pths <- file.find(getwd(), "globals.R")
#  pths
#  
#  # Look for Rdata files three levels up, and two levels down
#  pths <- file.find(getwd(), "*.Rdata", up = 3, down = 2)
#  pths

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare data
#  dat <- mtcars
#  
#  # View names
#  names(dat)
#  # [1] "mpg"  "cyl"  "disp" "hp"   "drat" "wt"   "qsec" "vs"   "am"   "gear" "carb"
#  
#  # Get all names starting with "c"
#  find.names(dat, pattern = "c*")
#  # [1] "cyl"  "carb"
#  
#  # Get all names starting with "c" or "d"
#  find.names(dat, pattern = c("c*", "d*"))
#  # [1] "cyl"  "carb" "disp" "drat"
#  
#  # Get names starting with "c" or "d" from column 4 on
#  find.names(dat, pattern = c("c*", "d*"), start = 4)
#  # [1] "carb" "drat"
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Prepare sample dataset
#  dat <- mtcars[ , 1:3]
#  
#  # Assign some labels
#  labels(dat) <- list(mpg = "Miles Per Gallon",
#                      cyl = "Cylinders",
#                      disp = "Displacement")
#  
#  # View labels
#  labels(dat)
#  # $mpg
#  # [1] "Miles Per Gallon"
#  #
#  # $cyl
#  # [1] "Cylinders"
#  #
#  # $disp
#  # [1] "Displacement"
#  
#  # Subset the data
#  dat2 <- subset(dat, cyl == 4)
#  
#  # Labels are gone!
#  labels(dat2)
#  # list()
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Restore attributes
#  dat2 <- copy.attributes(dat, dat2)
#  
#  # Labels are back!
#  labels(dat2)
#  # $mpg
#  # [1] "Miles Per Gallon"
#  #
#  # $cyl
#  # [1] "Cylinders"
#  #
#  # $disp
#  # [1] "Displacement"
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Separate two strings by 25 spaces
#  str <- paste0("Left", paste0(rep(" ", 25), collapse = ""), "Right", collapse = "")
#  str
#  # [1] "Left                         Right"
#  

## ----eval=FALSE, echo=TRUE----------------------------------------------------
#  # Separate two strings by 25 spaces
#  str <- "Left" %p% spaces(25) %p% "Right"
#  str
#  # [1] "Left                         Right"

Try the common package in your browser

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

common documentation built on Oct. 26, 2023, 1:08 a.m.