I know the basics like ==
and !=
, or even the difference (vaguely) between &
and &&
. But stuff like %in%
and %%
and some stuff used in the context of sprintf()
, like sprintf("%.2f", x)
stuff I have no idea about.
Worst of all, they're hard to search for on the Internet because they're special characters and I don't know what they're called...
There are several different things going on here with the percent symbol:
As several have already pointed out, things of the form %%
, %in%
, %*%
are binary operators (respectively modulo, match, and matrix multiply), just like a +
, -
, etc. They are functions that operate on two arguments that R recognizes as being special due to their name structure (starts and ends with a %
). This allows you to use them in form:
Argument1 %fun_name% Argument2
instead of the more traditional:
fun_name(Argument1, Argument2)
Keep in mind that the following are equivalent:
10 %% 2 == `%%`(10, 2)
"hello" %in% c("hello", "world") == `%in%`("hello", c("hello", "world"))
10 + 2 == `+`(10, 2)
R just recognizes the standard operators as well as the %x%
operators as special and allows you to use them as traditional binary operators if you don't quote them. If you quote them (in the examples above with backticks), you can use them as standard two argument functions.
The big difference between the standard binary operators and %x%
operators is that you can define custom binary operators and R will recognize them as special and treat them as binary operators:
`%samp%` <- function(e1, e2) sample(e1, e2)
1:10 %samp% 2
# [1] 1 9
Here we defined a binary operator version of the sample function
The meaning of "%"
in function like sprintf
or format
is completely different and has nothing to do with binary operators. The key thing to note is that in those functions the %
character is part of a quoted string, and not a standard symbol on the command line (i.e. "%"
and %
are very different). In the context of sprintf
, inside a string, "%"
is a special character used to recognize that the subsequent characters have a special meaning and should not be interpreted as regular text. For example, in:
sprintf("I'm a number: %.2f", runif(3))
# [1] "I'm a number: 0.96" "I'm a number: 0.74" "I'm a number: 0.99"
"%.2f"
means a floating point number (f
) to be displayed with two decimals (.2
). Notice how the "I'm a number: "
piece is interpreted literally. The use of "%"
allows sprintf
users to mix literal text with special instructions on how to represent the other sprintf
arguments.