使用Shiny制作表格

作者: Chientung | 来源:发表于2016-03-05 16:21 被阅读1024次

    表格是工作和生活中常见的数据呈现方式,例如公司的很多报表就需要用到表格。当我们展示数据的时候,用户当然不希望只看到一个静态的页面,所以就需要一些简单的交互功能:排序、查找、筛选等等。

    基础的需求并不难实现,但当我们使用其他网页技术做这件事情的时候,既要做前端,也要做后端,代码量也不会少。对技术小白来说,使用 R Shiny 做这样的事情就很容易了。

    ShinyR 社区里面一个非常出名的包,用来制作各类交互式网络应用,我们熟知的谢益辉就是其中的一位作者。

    先睹为快看看 Shiny 能做出什么样的效果:

    可以看出来, Shiny 简直天生就是为了交互而存在的。

    Shiny 也提供了非常丰富的 widgets ,几乎覆盖了我们对 UI 的全部需求:

    DT 也是谢老大写的包,是 JavaScript DataTables 库的R接口,R的数据对象可以直接通过 DT 呈现为HTML的表格。不仅如此, DT 本身还自动支持筛选、分页、排序等功能,非常的强大。

    一言以蔽之, Shiny + DT 是交互式呈现表格的非常好的一个方案。

    下面以我最近做的一个表格为例,最终效果是这样的:


    数据来源于这里,爬下来就行。

    首先把爬下来的数据打包成一个数据框:

    myData<-data.frame(...)
    

    记得load一下两个要用到的包:

    library(shiny)
    library(DT)
    

    UI端的代码:

    shinyUI(
      fluidPage(
        titlePanel("0~3岁婴儿/父母-婴幼儿启蒙教育"),
        downloadButton('downloadData', 'Download'),
    
        fluidRow(
        DT::dataTableOutput("table")
        )
      )
    )
    

    Server端的代码:

    shinyServer(function(input, output) {
    
        output$table <- DT::renderDataTable(DT::datatable({
            myData
        }, rownames = FALSE))
    
        output$downloadData <- downloadHandler(
            filename = 'file.csv',
            content = function(file) {
                write.csv(table, file)
            }
        )
    })
    

    我们可以对任何一列数据进行排序,也可以筛选或查找任何内容,非常的方便。

    最后只要把代码打包上传部署好 Shiny Server 的服务器就可以访问了 :)

    相关文章

      网友评论

      • 茶苯海:shiny sever的服务器?
      • 划船的浆不浪:你好,我上传的文件也是中文数据文件,但是在生成datatable时候,在切换数据展示长度的时候,提示table id = datatable 1 , invalid json response,一切换页数的时候就提示这个,请问是什么原因?

      本文标题:使用Shiny制作表格

      本文链接:https://www.haomeiwen.com/subject/amtakttx.html