data:image/s3,"s3://crabby-images/7026f/7026fdaf306a9291a059d65ca93cc2da7ee23fd0" alt=""
Add conditional formatting to a workbook
Source:vignettes/conditional-formatting.Rmd
conditional-formatting.Rmd
wb <- wb_workbook()
wb$add_dxfs_style(name = "negStyle", font_color = wb_color(hex = "FF9C0006"), bg_fill = wb_color(hex = "FFFFC7CE"))
wb$add_dxfs_style(name = "posStyle", font_color = wb_color(hex = "FF006100"), bg_fill = wb_color(hex = "FFC6EFCE"))
Rule applies to all each cell in range
data:image/s3,"s3://crabby-images/47e85/47e8529dd9be256f4be2cb83e6746861d4f087c0" alt="Basic conditional formatting"
Basic conditional formatting
wb$add_worksheet("cellIs")
wb$add_data("cellIs", -5:5)
wb$add_data("cellIs", LETTERS[1:11], start_col = 2)
wb$add_conditional_formatting(
"cellIs",
dims = "A1:A11",
rule = "!=0",
style = "negStyle"
)
wb$add_conditional_formatting(
"cellIs",
dims = "A1:A11",
rule = "==0",
style = "posStyle"
)
Highlight row dependent on first cell in row
data:image/s3,"s3://crabby-images/c4f28/c4f28ccadc0ad84d91bc6bf166500b06b06525a7" alt="Moving row conditional formatting"
Moving row conditional formatting
wb$add_worksheet("Moving Row")
wb$add_data("Moving Row", -5:5)
wb$add_data("Moving Row", LETTERS[1:11], start_col = 2)
wb$add_conditional_formatting(
"Moving Row",
dims = "A1:B11",
rule = "$A1<0",
style = "negStyle"
)
wb$add_conditional_formatting(
"Moving Row",
dims = "A1:B11",
rule = "$A1>0",
style = "posStyle"
)
Highlight column dependent on first cell in column
data:image/s3,"s3://crabby-images/4989a/4989a75eeb2e5b486246f88cb58fcf69aa3519fd" alt="Moving column conditional formatting"
Moving column conditional formatting
wb$add_worksheet("Moving Col")
wb$add_data("Moving Col", -5:5)
wb$add_data("Moving Col", LETTERS[1:11], start_col = 2)
wb$add_conditional_formatting(
"Moving Col",
dims = "A1:B11",
rule = "A$1<0",
style = "negStyle"
)
wb$add_conditional_formatting(
"Moving Col",
dims = "A1:B11",
rule = "A$1>0",
style = "posStyle"
)
Highlight cell dependent on
data:image/s3,"s3://crabby-images/013c8/013c8527944e723524e2e3f2752fa9334881f4b9" alt="Dependent conditional formatting"
Dependent conditional formatting
Highlight entire range cols X rows dependent only on cell A1
wb$add_worksheet("Dependent on")
wb$add_data("Dependent on", -5:5)
wb$add_data("Dependent on", LETTERS[1:11], start_col = 2)
wb$add_conditional_formatting(
"Dependent on",
dims = "A1:B11",
rule = "$A$1 < 0",
style = "negStyle"
)
wb$add_conditional_formatting(
"Dependent on",
dims = "A1:B11",
rule = "$A$1>0",
style = "posStyle"
)
Highlight cells in column 1 based on value in column 2
wb$add_data("Dependent on", data.frame(x = 1:10, y = runif(10)), startRow = 15)
wb$add_conditional_formatting(
"Dependent on",
dims = "A16:A25",
rule = "B16<0.5",
style = "negStyle"
)
wb$add_conditional_formatting(
"Dependent on",
dims = "A16:A25",
rule = "B16>=0.5",
style = "posStyle"
)
Highlight duplicates using default style
data:image/s3,"s3://crabby-images/e8a63/e8a6317fc61ef16550f426608ddbe8aaa00f268c" alt="Duplicated conditional formatting"
Duplicated conditional formatting
wb$add_worksheet("Duplicates")
wb$add_data("Duplicates", sample(LETTERS[1:15], size = 10, replace = TRUE))
wb$add_conditional_formatting(
"Duplicates",
dims = "A1:A10",
type = "duplicatedValues"
)
Colorscale colors cells based on cell value
data:image/s3,"s3://crabby-images/34bf8/34bf8bcbb9527e6348237edc1a99206fb3a54512" alt="Colorscale conditional formatting (_Yep, that is a color scale image_)"
Colorscale conditional formatting (Yep, that is a color scale image)
df <- read_xlsx("https://github.com/JanMarvin/openxlsx-data/raw/main/readTest.xlsx", sheet = 5)
wb$add_worksheet("colorScale", zoom = 30)
wb$add_data(x = df, col_names = FALSE) ## write data.frame
Rule is a vector or colors of length 2 or 3 (any hex color or any of
colors()
). If rule is NULL
, min and max of
cells is used. Rule must be the same length as style or L.
wb$add_conditional_formatting(
sheet = "colorScale",
dims = wb_dims(
rows = seq_len(nrow(df)),
cols = seq_len(ncol(df))
),
# dims = wb_dims(x = df, col_names = FALSE, select = "data")
style = c("black", "white"),
rule = c(0, 255),
type = "colorScale"
)
wb$set_col_widths("colorScale", cols = seq_along(df), widths = 1.07)
wb$set_row_heights("colorScale", rows = seq_len(nrow(df)), heights = 7.5)
Databars
data:image/s3,"s3://crabby-images/dc670/dc6706115cd79857e6c5c352dcfde4761a0d9739" alt="Databar conditional formatting"
Databar conditional formatting
wb$add_worksheet("databar")
## Databars
wb$add_data("databar", -5:5, start_col = 1)
wb <- wb_add_conditional_formatting(
wb,
"databar",
dims = "A1:A11",
type = "dataBar"
) ## Default colors
wb$add_data("databar", -5:5, start_col = 3)
wb <- wb_add_conditional_formatting(
wb,
"databar",
dims = "C1:C11",
type = "dataBar",
params = list(
showValue = FALSE,
gradient = FALSE
)
) ## Default colors
wb$add_data("databar", -5:5, start_col = 5)
wb <- wb_add_conditional_formatting(
wb,
sheet = "databar",
dims = "E1:E11",
type = "dataBar",
style = c("#a6a6a6"),
params = list(showValue = FALSE)
)
wb$add_data("databar", -5:5, start_col = 7)
wb <- wb_add_conditional_formatting(
wb,
"databar",
dims = "G1:G11",
type = "dataBar",
style = c("red"),
params = list(
showValue = TRUE,
gradient = FALSE
)
)
# custom color
wb$add_data("databar", -5:5, start_col = 9)
wb <- wb_add_conditional_formatting(
wb,
"databar",
dims = wb_dims(rows = 1:11, cols = 9),
type = "dataBar",
style = c("#a6a6a6", "#a6a6a6"),
params = list(showValue = TRUE, gradient = FALSE)
)
# with rule
wb$add_data(x = -5:5, start_col = 11)
wb <- wb_add_conditional_formatting(
wb,
"databar",
dims = wb_dims(rows = 1:11, cols = 11),
type = "dataBar",
rule = c(0, 5),
style = c("#a6a6a6", "#a6a6a6"),
params = list(showValue = TRUE, gradient = FALSE)
)
Top N
data:image/s3,"s3://crabby-images/8f2f7/8f2f741e8f1233b475caba72db4817ee1e558789" alt="Top n conditional formatting"
Top n conditional formatting
wb$add_data("topN", data.frame(x = 1:10, y = sample(1:100, 10)))
Highlight top 5 values in column x
wb$add_conditional_formatting(
"topN",
dims = wb_dims(rows = 2:11, cols = 1),
style = "posStyle",
type = "topN",
params = list(rank = 5)
)
Highlight top 20 percentage in column y
Bottom N
data:image/s3,"s3://crabby-images/0214f/0214fa7ac80d873928420d306e77f621a518e238" alt="Bottom n conditional formatting"
Bottom n conditional formatting
wb$add_data("bottomN", data.frame(x = 1:10, y = sample(1:100, 10)))
Highlight bottom 5 values in column x
wb$add_conditional_formatting(
"bottomN",
dims = wb_dims(rows = 2:11, cols = 1),
style = "negStyle",
type = "bottomN",
params = list(rank = 5)
)
Highlight bottom 20 percentage in column y
wb$add_conditional_formatting(
"bottomN",
cols = 2,
rows = 2:11,
style = "negStyle",
type = "bottomN",
params = list(rank = 20, percent = TRUE)
)
wb$add_worksheet("logical operators")
Logical Operators
data:image/s3,"s3://crabby-images/76daf/76daf78bdd478bee3663ec41a5101eae944ea4c6" alt="Logical operators conditional formatting"
Logical operators conditional formatting
You can use Excels logical Operators
wb$add_data("logical operators", 1:10)
wb$add_conditional_formatting(
"logical operators",
dims = wb_dims(rows = 1:10, cols = 1),
rule = "OR($A1=1,$A1=3,$A1=5,$A1=7)"
)