https://www.jianshu.com/p/7df62865c3ed

Rapp --简书

Microsoft的Office软件在办公软件领域占有绝对的主导地位,几乎每个职场人士都必须掌握Word,Excel和PPT的使用。对于R用户来说,用来处理表格的Excel早就可以弃之不用,但是在撰写报告的时候还是离不开Word和PPT。尽管我们也可以利用kniter和Rmarkdown 等软件包自动生成报告,但它们更擅长生成HTML格式的文档(网页形式),在生成Word和PPT文档的时候功能有限,并不是很好用。
如果你的老板或者客户更喜欢阅读Word和PPT,而你又想利用R语言来自动生成报告,提高工作效率和可重复性,那么今天介绍的ReporteRs包将会是你的最佳选择。

ReporteRs的主页:

 
webpage.png

http://davidgohel.github.io/ReporteRs/index.html

  1. 安装ReporteRs
    1.1 查看你的系统中是否已经安装Java(在终端中输入 java -version),如果没有,请安装Java(version>=1.6),具体方法请百度
    1.2 在系统中安装cairo(以Ubuntu为例): sudo apt-get install libcairo2-dev
    1.3 在RStudio里安装 rJava 软件包: install.packages('rJava')
    1.4 在RStudio里安装ReporteRs软件包: install.packages('ReporteRs')
    1.5 运行ReporteRs网站首页上的一段示例代码,如果能顺利地生成 my_first_doc.docx 文档就表明安装成功,可以开始正式学习ReporteRs了

     
    my_first_doc.png
  2. ReporteRs 的精髓: FlexTable
    在Word中添加格式化的表格是最繁琐的工作,我使用过的其他R软件包都不能完美地解决我遇到的所有问题,而ReporteRs的FlexTable让我有种相见恨晚的感觉,我觉得它是ReporteRs的精髓所在。
    FlexTable的表格模型如下:

     
    table_model.png

    (1)灰色的部分是表头,多行表头在实际工作中经常会遇到,FlexTable 给出了完美的解决方案
    (2)深蓝色表示的是表格的数据部分,“合并单元格”或者“对单元格/数字标注颜色”也是经常会遇到的问题,用其他软件包很难实现,而FlexTable也考虑到了
    (3)浅蓝色部分是表格的脚注,同样也考虑了多行的情况
    由于篇幅有限,下面我只从ReporteRs网站上挑选几个FlexTable的例子,感兴趣的读者可以到网站上查看完整的代码。
    手中的数据是这样的:

     
    flextable_1.png

    基本款的FlexTable是这样的:

     
    flextable_2.png

    常用的三线表是这样轻松生成的:

     
    flextable_3.png

    合并单元格终于有了完美的解决方法:

     
    flextable_4.png

    改变某个单元格的背景色也是如此轻松:

     
    flextable_5.png

    上面的例子略显丑陋,在文档中经常出现的还是这样的配色:

     
    flextable_6.png

    轻松添加表头,让表格更加容易阅读:

     
    flextable_7.png
  3. 创建Word文档(.docx)或PPT文档(.pptx)大致可分为以下3个步骤:
    (1)创建docx或pptx对象(可以使用 template file)
    (2)将R程序的输出(text, table, plots)添加到对象中(对于pptx文档要先在对象中添加一个silde)
    (3)将对象写入文件

  4. ReporteRs 函数
    熟练掌握ReporteRs的函数是创建自动化报告的基础,我建议大家边学习变实践。我将ReporteRs的函数做了归类(见下图),可以方便大家记忆。当遇到函数参数设置的问题时,别忘记查看ReporteRs的文档。

     
    functions.png
  5. 模板的使用
    真正要想做到报告的自动化生成,模板的使用是必不可少的。只要将文档的静态内容和格式定义好,写成一个模板,ReporteRs就可以把R程序产生的新的结果按照文档要求的格式插入到模板的指定位置中。具体方法如下:
    (1)在Word文档中的某个位置插入书签(bookmarks),书签就相当与文档中的一个有名称的位置。注意,这部分操作是在Word软件中进行的,具体方法可以百度,或者查看下面的链接: http://www.wikihow.com/Add-a-Bookmark-in-Microsoft-Word
    (2)只要把书签名赋给bookmark参数,addFlexTable, addPlot, addParagraph和addImage函数就可以将文档中的书签替换成相应的图表或文字。

作者:Rapp
链接:https://www.jianshu.com/p/7df62865c3ed
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

用R创建Word和PowerPoint文档--转载的更多相关文章

  1. C#/VB.NET 向PowerPoint文档插入视频

    如今,Microsoft Office PowerPoint在我们日常生活中的应用已经很广泛了,利用Microsoft Office PowerPoint不仅可以创建演示文稿,还可以在互联网上召开面对 ...

  2. 如何把PPT变小|PowerPoint文档减肥的几种方法

    使用powerpoint制作幻灯片的过程中,经常出现过这样的情况,制作幻灯片时,出于内容的需要和美观的需要,添加了许多图片和Excel表或者OLE对象,成倍增大了文档的体积,结果导致: 1.页面编辑人 ...

  3. C# 调用word进程操作文档关闭进程

    C# 调用word进程操作文档关闭进程 作者:Jesai 时间:2018-02-12 20:36:23 前言: office办公软件作为现在主流的一款办公软件,在我们的日常生活和日常工作里面几乎每天都 ...

  4. 基于DevExpress实现对PDF、Word、Excel文档的预览及操作处理

    http://www.cnblogs.com/wuhuacong/p/4175266.html 在一般的管理系统模块里面,越来越多的设计到一些常用文档的上传保存操作,其中如PDF.Word.Excel ...

  5. Aspose.Words操作word生成PDF文档

    Aspose.Words操作word生成PDF文档 using Aspose.Words; using System; using System.Collections.Generic; using ...

  6. (转)创建和查看Javadoc文档

    原地址:http://jinnaxu-tju-edu-cn.iteye.com/blog/667177 Javadoc是Sun公司提供的一个技术,它从程序源代码中抽取类.方法.成员等注释形成一个和源代 ...

  7. 1.2.3 创建Cocos2D-iPhone的帮助文档

    http://book.51cto.com/art/201303/383957.htm <Cocos2D权威指南>第1章开始前的准备工作,本章我们将介绍什么是Cocos2D以及有关Coco ...

  8. Win7如何自定义鼠标右键菜单 添加新建PowerPoint文档

    鼠标右键添加新建PowerPoint文档.reg Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\.ppt] "Content ...

  9. swagger2 导出离线Word/PDF/HTML文档

    swagger2离线导出Word/PDF/HTML文档 1.前言 通过前面的两篇博客 我们已经介绍了如何使用spring boot整合swagger2 生成在线的API文档. 但是某些情况下,我们需要 ...

随机推荐

  1. <转>jmeter(十三)常见问题及解决方法

    本博客转载自:http://www.cnblogs.com/imyalost/category/846346.html 个人感觉不错,对jmeter讲解非常详细,担心以后找不到了,所以转发出来,留着慢 ...

  2. kubernetes install for centos

    官方的文档写的很清楚 https://kubernetes.io/docs/getting-started-guides/centos/centos_manual_config/ 如果已经安装过doc ...

  3. The Little Prince-12/13

    The Little Prince-12/13 突然发现:这应该是一封情书~ 我那时什么也不懂!我应该根据她的行为,而不是根据她的话来判断她. 她使我的生活芬芳多彩,我真不该离开她跑出来.我本应该猜出 ...

  4. 学写网页 #06# table

    A B E C D <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> & ...

  5. Caused by: java.lang.ClassNotFoundException: Illegal access: this web application instance has been stopped already. Could not load [org.jboss.netty.util.internal.ByteBufferUtil]. The following stack

    Caused by: java.lang.ClassNotFoundException: Illegal access: this web application instance has been ...

  6. Docker学习笔记之docker volume 容器卷的那些事(二)

    预览目录 更改目录拥有者 Data Container 切换用户 参考文章 0x00 概述 如果你读了docker volume 容器卷的那些事(一),我想应该不会遇到下面这些问题的,毕竟是具有指导意 ...

  7. php简单使用shmop函数创建共享内存减少服务器负载

    在之前的一篇博客[了解一下共享内存的概念及优缺点]已经对共享内存的概念做了说明.下面就来简单使用共享内存(其实也可以用其他工具,比如redis) PHP做内存共享有两套接口.一个是shm,它实际上是变 ...

  8. CSM与UEFI

    最近公司产品部购置一批新电脑,但是预装的win10不能保证兼容老平台软件,于是安装win7系统的任务就落到了我的手中. 观察参数,是8代的U,产品说运维说无能为力,装不了win7.我在网上搜了一下,是 ...

  9. Solr导入MySQL数据之dataimport-handler

    Solr不借助手动JSolr编程情况下也可以将Mysql的数据导入到Solr中.实现方式是安装dataimport-Handler从关系数据库将数据导入到索引库. 1.向SolrCore中加入jar包 ...

  10. Solr基本操作

    /update 使用/update进行索引维护,进入Solr管理界面SolrCore下的Document下: 我们进行更新操作可以用json和xml多种格式,这里以xml格式为例说明.先来看看界面上的 ...