Подтвердить что ты не робот

Как поместить новую строку в заголовок столбца в xxtable в R

У меня есть dataframe, который я помещаю в документ sweave с использованием xtable, однако одно из моих имен столбцов довольно длинное, и Я хотел бы разбить его на две строки, чтобы сэкономить место

calqc_table<-structure(list(RUNID = c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L), ANALYTEINDEX = c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L), ID = structure(1:11, .Label = c("Cal A", "Cal B", "Cal C", 
"Cal D", "Cal E", "Cal F", "Cal G", "Cal H", "Cal High", "Cal Low", 
"Cal Mid"), class = "factor"), mean_conc = c(200.619459644855, 
158.264703128903, 102.469121407733, 50.3551544728544, 9.88296440865076, 
4.41727762501703, 2.53494715706024, 1.00602831741361, 199.065054555735, 
2.48063347296935, 50.1499780776199), sd_conc = c(2.3275711264554, 
NA, NA, NA, NA, NA, NA, 0.101636943231162, 0, 0, 0), nrow = c(3, 
1, 1, 1, 1, 1, 1, 3, 2, 2, 2)), .Names = c("Identifier of the Run within the Study", "ANALYTEINDEX", 
"ID", "mean_conc", "sd_conc", "nrow"), row.names = c(NA, -11L
), class = "data.frame")
calqc_xtable<-xtable(calqc_table)

Я попытался поместить новую строку в имя, но это, похоже, не работает

names(calqc_table)[1]<-"Identifier of the \nRun within the Study"

Есть ли способ сделать это? Я видел, как кто-то предложил использовать функцию латекса из пакета hmisc для ручного перебора по таблице и записи вручную в латекс, включая newline, но это похоже на faf!

4b9b3361

Ответ 1

Лучший способ, который я нашел для этого, - указать столбец таблицы как столбец "фиксированной ширины", чтобы текст внутри него обертывался. С пакетом xtable это можно сделать с помощью:

align( calqc_xtable ) <- c( 'l', 'p{1.5in}', rep('c',5) )

xtable требует, чтобы вы предоставили выравнивание для столбца опций "rownames" - это начальная спецификация l. Спецификация раздела p{1.5in} используется для вашего первого заголовка столбца, который довольно длинный. Это ограничивает его шириной в 1,5 дюйма и заголовок наматывается на несколько строк, если это необходимо. Остальные пять столбцов центрируются с использованием спецификатора c.

Одна из основных проблем с столбцами с фиксированной шириной, такими как p{1.5in}, заключается в том, что они устанавливают текст с использованием выравнивания выравнивания. Это приводит к расширению интервала между словами в каждой строке, так что линия будет заполнять все выделенные 1,5 дюйма.

Честно говоря, в большинстве случаев это приводит к результатам, которые я не могу описать с использованием вежливого языка (я - любительский типографский орех, и такое поведение вызывает лицевые клещи).

Исправление состоит в том, чтобы предоставить команду выравнивания латекса путем добавления поля >{} к спецификации столбца:

align( calqc_xtable ) <- c( 'l', '>{\\centering}p{1.5in}', rep('c',4) )

Другими полезными командами выравнивания являются:

  • \raggedright → заставляет текст выравниваться по левому краю
  • \raggedleft → вызывает выравнивание текста

Не забудьте удвоить обратную косую черту, чтобы избежать их в R-строках. Вам также может потребоваться отключить функцию очистки строки, которая по умолчанию используется xtable.

Примечание

Этот метод выравнивания не удастся, если он используется в последнем столбце таблицы , если строки таблицы не заканчиваются \tabularnewline вместо \\, что, я думаю, не в случае с xtable и не легко настраивается с помощью любого настраиваемого пользователем варианта.

Другая вещь, которую следует учитывать, - это то, что вам может не потребоваться, чтобы весь столбец был перенесен на 1,5 дюйма и центрирован - только заголовок. В этом случае отключите дезинфекцию строки xtable и установите свой заголовок, используя ячейку \multicolumn шириной 1:

names(calqc_table)[1]<-"\\multicolumn{1}{>{\\centering}p{1.5in}}{Identifier of the Run within the Study}"

Ответ 2

Метод @Sharpie не работал у меня, поскольку pandoc не удалось с ошибкой 43 при преобразовании в pdf. Поэтому вот что я сделал:

переместил маркер \\centering:

names(calqc_table)=c(rep("\\multicolumn{1}{p{0.75in}}{\\centering Identifier of the Run within the Study}", 6))

(здесь применяется ко всем 6 столбцам таблицы)

и отключена дезинфекция в xtable-печати:

print(calqc_table, sanitize.colnames.function=function(x){x})