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

Скрытие NA при печати данных в knitr

Я пытаюсь распечатать таблицу в knitr из фрейма данных с помощью xtable. Таблица в примере ниже имеет размеры 3x7, но третья строка имеет только одно значение во втором столбце. Остальные ячейки в третьем ряду - "NA".

Когда я компилирую документ, есть ли способ запретить knitr печатать NA в третьей строке, поэтому вместо NA у меня просто пустое пространство?

Похоже, это должно быть простым решением, но я не могу понять, где/как скрыть NA. Является ли это изменением, которое мне нужно сделать в кадре данных, или это вариант xxtable или knitr, который мне нужно изменить?

Пример кода:

\documentclass{article}

<< data1, echo=FALSE,  warning=FALSE, message=FALSE >>=

require(xtable)

  FY.2014 <- 0.019
  FY.2015 <- ((7000)  - (6925.9)) / (6925.9)
  FY.2016 <- ((8000)  - (7000))   / (7000)
  FY.2017 <- ((9000)  - (8000))   / (8000)
  FY.2018 <- ((10000) - (9000))   / (9000)
  FY.2019 <- ((11000) - (10000))  / (10000)

  PC      <- data.frame(FY.2014, FY.2015, FY.2016, FY.2017, FY.2018, FY.2019)
  PC.1    <- paste(round(PC*100, digits=1), "%", sep="")


 FY.2014 <- 130.1
 FY.2015 <- 7000  - 6925.9
 FY.2016 <- 8000  - 7000
 FY.2017 <- 9000  - 8000
 FY.2018 <- 10000 - 9000
 FY.2019 <- 11000 - 10000

 AB      <- data.frame(FY.2014, FY.2015, FY.2016, FY.2017, FY.2018, FY.2019)
 AB.1    <- paste(round(AB , digits = 2))


    FY.2014 <- as.numeric(c(""))
    FY.2015 <- 7242.9
    FY.2016 <- as.numeric(c(""))
    FY.2017 <- as.numeric(c(""))
    FY.2018 <- as.numeric(c(""))
    FY.2019 <- as.numeric(c(""))

    PF      <- data.frame(FY.2014, FY.2015, FY.2016, FY.2017, FY.2018, FY.2019)
    PF.1    <- paste(round(PF , digits = 2))

     FTable  <- rbind( PC.1, AB.1, PF.1)

      rownames(FTable) <- c( 'Percent Change from the Previous Year', 
                             'Absolute Change from Previous Year', 
                             'December CY13 Forecast')
      colnames(FTable) <- c( 'FY 2014', 'FY 2015', 'FY 2016', 'FY 2017', 'FY 2018',    'FY 2019')

@ 

\begin{document}
<<Table 1 , echo=FALSE, eval=TRUE, results='asis', fig.width = 5, fig.height = 2,     message=FALSE, fig.align='center', warning=FALSE>>=

          xFTable  <- xtable(FTable, big.mark=",")

          print(xFTable) 
@
\end{document}
4b9b3361

Ответ 1

Вы можете установить опцию knitr knitr.kable.na = '' '' для пробелов или любого другого символа, который вы хотите.

```{r echo=FALSE, results='asis'}
    options(knitr.kable.NA = '')
    knitr::kable(lowerTri, digits=2)
```

Ответ 2

Трюк, который я использую, является немного грубой силой, но, похоже, он работает (в моих случаях использования):

out <- knitr::kable(...)
cat(gsub('\\bNA\\b', '  ', out), sep='\n')