美文网首页
docker安装libreoffice并实现把Excel转为pd

docker安装libreoffice并实现把Excel转为pd

作者: 逍遥无铭 | 来源:发表于2019-07-11 16:50 被阅读0次

    1.下载Centos镜像

    docker pull centos
    

    2.进入容器

    docker run -it -d  centos /bin/bash
    

    -t: 让docker分配一个伪终端并绑定到容器的标准输入上;
    -i: 让容器的标准输入保持打开,这时bash命令才不会自动退出;
    -d: 让容器在后台运行。
    如果没有-d,则会进入容器交互模式,输入exit命令后,会导致容器退出运行状态。加上-d, exit命令退出容器后,容器仍然能保持后台运行状态。

    执行docker exec进入centos容器

    docker exec -it centos /bin/bash
    

    3.安装libreoffice、中文字体库等所需的软件

    yum search libreoffice
    

    可以看到除了libreoffice,还有很多office单一的子模块
    yum目前的版本只到5.3.6.1,如果要安装最新的版本,需要从官网下载最新的安装包安装
    libreoffice.x86_64 : Free Software Productivity Suite
    libreoffice-calc.x86_64 : LibreOffice Spreadsheet Application
    libreoffice-writer.x86_64 : LibreOffice Word Processor Application
    libreoffice-draw.x86_64 : LibreOffice Drawing Application
    ......

    因为只需要处理Excel,所以就只安装libreoffice-calc.x86_64

    yum install libreoffice-calc.x86_64
    yum groupinstall "Fonts"
    yum groupinstall "Input Methods"
    

    4.生成安装了libreoffice、中文字体等软件的docker 镜像
    执行exit命令退出容器后在宿主机执行

    docker commit CONTAINER_ID alexxu/librexlsx
    

    通过docker ps|grep centos查看centos容器的container id.
    5.停掉刚才运行的centos容器

    docker stop CONTAINER_ID或是container_name(这里是centos)
    

    6.启动上面新生成的docker 镜像alexxu/librexlsx

    docker run –name libxlsx -it -d  -v /$HOME/data:/root/pdf  alexxu/librexlsx /bin/bash
    

    -v创建共享目录,将宿主机目录/$HOME/data 映射到容器的/root/pdf目录 ,把要转换的Excel文件indicator.xlsx放到/$HOME/data目录。

    进入容器

    docker run -it -d  centos /bin/bash
    

    执行命令:

    soffice --headless --invisible --convert-to pdf --outdir /root/pdf /root/pdf/indicator.xlsx
    

    则在/$HOME/data目录可以看到生成的indicator.pdf

    注意:如果你上面yum安装的是libreoffice而不是像我单独安装libreoffice-calc模块,导出时,导出命令最好加上output filter:calc_pdf_Export;如果是转word文档,则output filter类型为:writer_pdf_Export;这样明确告诉libreoffice是要哪个模块去转换。
    soffice --headless --invisible --convert-to pdf:calc_pdf_Export --outdir /root/pdf /root/pdf/indicator.xlsx
    因为我不确定libreoffice是不是能够自动识别你要转换的是Excel还是Word.
    libreoffice命令行参数作用可以查看:https://help.libreoffice.org/Common/Starting_the_Software_With_Parameters/zh-CN

    如果是在容器外执行。

    docker exec libxlsx /bin/bash -c 'soffice --headless --invisible --convert-to pdf --outdir /root/pdf /root/pdf/indicator.xlsx'
    

    以上就是怎样在linux环境通过libreoffice将Excel转换为pdf的详细过程。
    如果想转换为html, 则将参数 --convert-to pdf改为 --convert-to html就可以。

    相关文章

      网友评论

          本文标题:docker安装libreoffice并实现把Excel转为pd

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