使用 r xlsx 在 excel 文件中换行/换行

And*_*ico 5 excel newline r line-breaks xlsx

我想在我的 excel 结果中获得一个新行,例如我可以通过进入单元格并按Alt+Enter

数据+代码

df <- data.frame(a="Funny\\nNot",b="rofl\nlol",c="hihi\rh3h3")

xlsx::write.xlsx(df,file = "df.xlsx")
Run Code Online (Sandbox Code Playgroud)

cle*_*ens 6

使用包xlsx

'\'从列中删除转义a

df <- data.frame(a="Funny\nNot",b="rofl\nlol",c="hihi\rh3h3")

library(xlsx)
Run Code Online (Sandbox Code Playgroud)

创建工作簿和工作表对象:

wb <- createWorkbook() 
sheet <- createSheet(wb, sheetName="sheet1")
Run Code Online (Sandbox Code Playgroud)

添加数据框:

addDataFrame(df, sheet)
Run Code Online (Sandbox Code Playgroud)

从 wb/sheet 中获取第 2 行 B 列:

rows <- getRows(sheet, rowIndex = 2)

cell_b_2 <- getCells(rows, colIndex = 2)[[1]]
Run Code Online (Sandbox Code Playgroud)

在 Excel 中创建一个CellStyle集合Wrap Text

cs <- CellStyle(wb, alignment = Alignment(wrapText = TRUE))
Run Code Online (Sandbox Code Playgroud)

将其应用于单元格:

setCellStyle(cell_b_2, cs) 
Run Code Online (Sandbox Code Playgroud)

保存工作簿:

saveWorkbook(wb, 'df.xlsx')
Run Code Online (Sandbox Code Playgroud)

生成的工作簿如下所示:

excel输出


And*_*ico 5

感谢@lukeA 的点名。

当我用于wrap text包含"\n". 我得到了想要的结果。

这是我使用的代码:

wb <- xlsx::loadWorkbook("df.xlsx")
sheets <- xlsx::getSheets(wb)
sheet  <- sheets[[1]]                  # get specific sheet
rows   <- xlsx::getRows(sheet)         # get rows
cells  <- xlsx::getCells(rows)         # get cells
values <- lapply(cells, xlsx::getCellValue) # extract the cell values


wrapStyle <- xlsx::CellStyle(wb) + xlsx::Alignment(horizontal=NULL, vertical=NULL, wrapText=T,
                              rotation=0, indent=0)

lapply(names(cells),function(c)if(values[[c]] %>% grepl("\\n",.))xlsx::setCellStyle(cells[[c]],wrapStyle))

xlsx::saveWorkbook(wb,"dfWrap.xlsx")
Run Code Online (Sandbox Code Playgroud)