#! /usr/bin/env python

# -*- coding: utf-8 -*-

import fitz

import glob

import os

from win32com.client import Dispatch, constants, gencache

import sys,shutil

import datetime

print sys.getdefaultencoding()

#################word

def doc2pdf(input, output):
  w = Dispatch("Word.Application")
    
  try:
     doc = w.Documents.Open(input, ReadOnly = 1)
     doc.ExportAsFixedFormat(output, constants.wdExportFormatPDF, 
      Item = constants.wdExportDocumentWithMarkup, CreateBookmarks = constants.wdExportCreateHeadingBookmarks)
     return 0
  except Exception ,e:
     print str(e)
     return 1
  finally:
     w.Quit(constants.wdDoNotSaveChanges)
    

# Generate all the support we can.

def GenerateSupport():
  # enable python COM support for Word 2007
  # this is generated by: makepy.py -i "Microsoft Word 12.0 Object Library"
  gencache.EnsureModule('{00020905-0000-0000-C000-000000000046}', 0, 8, 4)
     

#####################

inputdoc = sys.argv[1]

store_tmp = unicode(os.path.splitext(inputdoc)[0],'GBK')

print inputdoc

outputpdf = os.path.splitext(inputdoc)[0]+'.pdf'

if (not os.path.isabs(inputdoc)):
     inputdoc = os.path.abspath(inputdoc)

if (not os.path.isabs(outputpdf)):
     outputpdf = os.path.abspath(outputpdf)

try:
     GenerateSupport()
     rc = doc2pdf(inputdoc, outputpdf)
    

except Exception,e:
     print str(e)

def rightinput(desc):
     flag=True
     while(flag):
         instr = raw_input(desc)
         try:
             intnum = eval(instr)
             if type(intnum)==int:
                 flag = False
         except:
             print('ÇëÊäÈëÕýÕûÊý£¡')
             pass
     return intnum

#pdffile = glob.glob("*.pdf")[0]

pdffile = outputpdf

pdffile =  unicode(pdffile , "GBK")

print pdffile

doc = fitz.open(pdffile)

#flag = rightinput("ÊäÈ룺1£ºÈ«²¿Ò³Ã棻2£ºÑ¡ÔñÒ³Ãæ\t")

flag = 1

if flag == 1:
     strat = 0
     totaling = doc.pageCount

# else:

#   strat = rightinput('ÊäÈëÆðʼҳÃ棺') - 1

#   totaling = rightinput('ÊäÈë½áÊøÒ³Ã棺')

pdf2png = os.path.join(os.path.dirname(__file__),'pdf2png')

pdf2png_old = os.path.join(pdf2png,'old')

if not os.path.isdir(pdf2png):
     os.mkdir(pdf2png)

if not os.path.isdir(pdf2png_old):
     os.mkdir(pdf2png_old)

n_t = datetime.datetime.now().strftime('%Y%m%d%H%M%S')

for  f in os.listdir(pdf2png):
         #print f.endswith('png')
         if f.endswith('png'):
             try:
                 src = os.path.join(pdf2png,f)
                 dst = os.path.join(pdf2png_old,f)
                 shutil.move(src,dst)
             except Exception,e:
                 pass

for pg in range(strat, totaling):
     page = doc[pg]
     zoom = int(100)
     rotate = int(0)
     trans = fitz.Matrix(zoom / 100.0, zoom / 100.0).preRotate(rotate)
     pm = page.getPixmap(matrix=trans, alpha=False)
     pm.writePNG(pdf2png+'/%s_%s_%s.png' % (store_tmp,n_t,str(pg+1)))

word 转pdf 再转图片--用在轻社群发文章的更多相关文章

  1. openOffice word转pdf,pdf转图片优化版

    之前写了一个版本的,不过代码繁琐而且不好用,效率有些问题.尤其pdf转图片速度太慢.下面是优化版本的代码. spriing_boot 版本信息:2.0.1.RELEASE 1.配置信息: packag ...

  2. Word转pdf,再转图片插入PDF

    WORD转PDF所需jar包: https://yangtaotao.lanzous.com/ice1jlc PDF转图片所需jar包: https://yangtaotao.lanzous.com/ ...

  3. C#实现 word、pdf、ppt 转为图片

    office word文档.pdf文档.powerpoint幻灯片是非常常用的文档类型,在现实中经常有需求需要将它们转换成图片 -- 即将word.pdf.ppt文档的每一页转换成一张对应的图片,就像 ...

  4. word、pdf、ppt 转为图片

    office word文档.pdf文档.powerpoint幻灯片是非常常用的文档类型,在现实中经常有需求需要将它们转换成图片 -- 即将word.pdf.ppt文档的每一页转换成一张对应的图片,就像 ...

  5. 解决word转pdf后图片失真

    碰到问题: 将word转pdf后图片出现失真 问题分析: 上述问题必定跟图片类型和所用软件有关,现将不同图片在不同软件下的失真情况汇总,见表1 问题解决:迫不得已,不要使用截图:若必需要用,则word ...

  6. word转pdf图片问题

    经过整理总结出两类问题:1,pdf文件下载文档中某些图片显示红叉.     问题现象:pdf是通过word转换成,发现源文件doc和docx文档均出现上述问题:只是某些图片显示红叉.通过这两点确定和文 ...

  7. CAD转PDF再由pdf转jpg图片

    免费的PDF转JPG图片 https://www.gaitubao.com/pdf-to-jpg/

  8. 采用jacob实现word转pdf

    网络上已经有很多这方面的内容,在用之前也是参考了好多别人的文章,下面记录下我自己的整合过程.整个过程都比较简单: 开发环境:win8 64位系统,在2008下面部署也是一样的. 文档要求jdk的版本要 ...

  9. C#操作word模板插入文字、图片及表格详细步骤

    c#操作word模板插入文字.图片及表格 1.建立word模板文件 person.dot用书签 标示相关字段的填充位置 2.建立web应用程序 加入Microsoft.Office.Interop.W ...

随机推荐

  1. nginx 实际部署配置文件示例

    user nobody; worker_processes ; error_log logs/error.log; pid logs/nginx.pid; events { worker_connec ...

  2. 数据结构与算法系列——排序(4)_Shell希尔排序

    1. 工作原理(定义) 希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本.但希尔排序是非稳定排序算法. 希尔排序的基本思想是:先将整个待排序的记录序列分割成为若干子序列分别进行直接插入 ...

  3. Flask项目之login提交

    #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2019/11/2 20:53 # @Author : zoulixiang # @Si ...

  4. Spring Security教程之Jsp标签(八)

    目录 1.1     authorize 1.2     authentication 1.3     accesscontrollist Spring Security也有对Jsp标签的支持的标签库 ...

  5. 【技术博客】Django中文件下载的实现

    开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. Django中文件下载的实现 1.背景 在VisualPy ...

  6. 《Linux就该这么学》培训笔记_ch10_使用Apache服务部署静态网站

    <Linux就该这么学>培训笔记_ch10_使用Apache服务部署静态网站 文章最后会post上书本的笔记照片. 文章主要内容: 网站服务程序 配置服务文件参数 SELinux安全子系统 ...

  7. python项目文件夹

    项目的文件夹 conf 用于存放配置文件的文件夹 core 核心业务代码 .py interface 接口, 接口内写获取数据前的逻辑代码,通过后才能获取数据 db 目前我们用于存放文件信息的 lib ...

  8. Effective.Java第67-77条(异常相关)

    67.  明智审慎地进行优化 有三条优化的格言是每个人都应该知道的: (1)比起其他任何单一的原因(包括盲目的愚钝),很多计算上的过失都被归咎于效率(不一定能实现) (2)不要去计算效率上的一些小小的 ...

  9. 【转】潜说js对象和数组

    /* 数组和对象 [JavaScript 权威指南 第五版] */ /* 对象: 是一个无序属性集合, 每个属性都有自己的名字和值 */ /* 创建对象简单方法, 对象直接量 */ var obj = ...

  10. 『LCA 树链剖分』

    LCA Description 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根 的距离+1. 设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公 ...