【问题标题】:comparing excel sheets in R比较R中的excel表
【发布时间】:2016-05-23 17:04:26
【问题描述】:

我有两个带有多个工作表的 excel 文件。两个文件的工作表名称及其对应的列名称相同。只有工作表中的值会有所不同。我想使用 R 比较哪些值不同并想标记这些单元格

【问题讨论】:

  • 我不确定这是否可以从 R 中实现。使用宏代替将是更方便的方法。另请参阅:stackoverflow.com/questions/18511249/…
  • 感谢您的链接,但是是的,在宏中很容易并且已经完成,但我特别需要在 R 中,所以我需要这个帮助。
  • XLConnect
  • 你想如何“标记那些单元格”?更改格式,例如阴影,或将文本加粗等?
  • 请添加您尝试过的内容。 StackOverflow 不是代码编写服务。

标签: r comparison


【解决方案1】:

为了好玩,这里有一个简单粗暴的示例,您可以根据自己的特定需求进行构建:

wbsCreate <- function(v) {
  wb <- createWorkbook()
  sheet <- createSheet(wb, "Sheet1")
  rows  <- createRow(sheet, rowIndex=1:5)
  cells <- createCell(rows, colIndex=1:5) 
  for (r in 1:5)
    for (c in 1:5)
      setCellValue(cells[[r, c]], value = v[(r-1)*5+c])
  saveWorkbook(wb, tf <- tempfile(fileext = ".xlsx"))
  return(tf)
}

wbsMarkDiff <- function(fn1, fn2) {
  fns <- c(fn1, fn2)
  wb <- lapply(fns, loadWorkbook)  
  cs <- lapply(wb, function(x) CellStyle(x) + 
                 Fill(backgroundColor="red", 
                      foregroundColor="red", 
                      pattern="SOLID_FOREGROUND"))
  sheets <- lapply(wb, getSheets)
  sheetnames <- do.call(intersect, lapply(sheets, names))
  for (sheetname in sheetnames) {
    sheet <- lapply(sheets, "[[", sheetname)
    rows <- lapply(sheet, getRows)
    cells <- lapply(rows, getCells)
    values <- lapply(cells, function(cell) lapply(cell, getCellValue))
    idx <- names(which(!mapply(identical, values[[1]], values[[2]])))
    for (s in 1:2) 
      for (i in idx) 
        setCellStyle(cells[[s]][[i]], cs[[s]])
    for (s in 1:2)
      saveWorkbook(wb[[s]], fns[s])
  }
}

library(xlsx)

# create to excel workbooks (same dimensions per sheet)    
v <- LETTERS[1:25]
tf1 <- wbsCreate(v)
v[c(3,6,9)] <- letters[c(3,6,9)]
tf2 <- wbsCreate(v)

# mark differences     
wbsMarkDiff(tf1, tf2)
shell.exec(tf1) # open file1 on windows
shell.exec(tf2) # open file2 on windows

您可以使用? 获得有关每个命令的帮助,例如?createWorkbook 会为您提供有关该功能的帮助文件。

【讨论】:

  • xlsx 需要 Java,是否可以使用 openxlsx 和 writexlsx 的解决方法?
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-10-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多