Можно ли усечь вывод при просмотре содержимого DataFrames?
-
28-10-2019 - |
Вопрос
У меня есть кадр данных с некоторыми очень длинными колоннами «Комментарии». Когда я отображается, они разбиты на разные блоки, что затрудняет чтение в рядах. Можно ли изменить настройку в R или изменить вызов на Data.Frame, чтобы усечь строки на определенную длину?
Пример: 3-колона
data.frame(cbind(rep(1,5),rep(c("very very long obnoxious character string here" ,"dog","cat","dog",5)),rep(c("very very long obnoxious character string here" ,"dog","cat","dog",5))))
В результате DataFrame, как видно на моем экране:
X1 X2
1 1 very very long obnoxious character string here
2 1 dog
3 1 cat
4 1 dog
5 1 5
X3
1 very very long obnoxious character string here
2 dog
3 cat
4 dog
5 5
Решение
Я рекомендую такой явный способ, как это:
f <- function(x) data.frame(lapply(x, substr, 1, 5))
Применение:
> f(d)
X1 X2 X3
1 1 very very
2 1 dog dog
3 1 cat cat
4 1 dog dog
5 1 5 5
Хотя можно изменить поведение по умолчанию, я не рекомендую:
body(format.data.frame)[[5]] <- quote(for (i in 1L:nc) rval[[i]] <- substr(format(x[[i]], ..., justify = justify), 1, 5))
unlockBinding("format.data.frame", baseenv())
assign("format.data.frame", format.data.frame, pos = baseenv())
lockBinding("format.data.frame", baseenv())
rm(format.data.frame)
Применение:
> d
X1 X2 X3
1 1 very very
2 1 dog dog
3 1 cat cat
4 1 dog dog
5 1 5 5
Не связан с StackOverflow