java-pdf转word
注:原文来至 《 java-pdf转word 》
一: java Pdf 文字 转 Word
废话不说,直接上图
很简单的用法:
1、new个PDFBox对象
2、调用pdfToDoc()方法,再传一个参数(文件路径)
最新jar下载地址:链接:https://pan.baidu.com/s/1snqjpSx 密码:jujg 或者加QQ群: 464429490(在群文件中)
二:Java Pdf 图片表格 转 word
文章来源: 《 java-pdf转图片 》
很多人反应pdf转doc 图片丢失,表格丢失,样式丢失,编码问题等等。
没错这段代码就是只能把文字转为doc文件的
因为:stripper.writeText(doc,writer);
doc指doc文件
writer指 FileOutputStream fos=new FileOutputStream(“pdf文件地址”);
Writer writer=new OutputStreamWriter(fos,”UTF-8”);
所以我们想出了用js生成图片,或者pdf先转成图片
js全屏截图:
function takeScreenshot() {
html2canvas(document.body, {
onrendered: function(canvas) {
document.body.appendChild(canvas);
},
});
}
js生成pdf:
html2canvas(document.body, {
onrendered: function(canvas) {
var url = canvas.toDataURL();
//document.body.appendChild(canvas);
var doc = new jsPDF();
doc.setFontSize(40);
//doc.text(35, 25, "yanhui");
var imgAsDataURL = url;
doc.addImage(imgAsDataURL, 'JPEG', 15, 40, 420, 180);
doc.save('艳辉网.pdf');
},
width: 600,
height: 600
});
js预览pdf
window.onload = function () {
var success = new PDFObject({
url: "pdf/test.pdf",
pdfOpenParams: {
scrollbars: '0',
toolbar: '0',
statusbar: '0'
}
}).embed("pdf");
};
js那么强大,我们的java也不甘示弱
java实现pdf转图片 图片转pdf
//将pdf装图片 并且自定义图片得格式大小
File file = new File(pdfPath);
try {
PDDocument doc = PDDocument.load(file);
PDFRenderer renderer = new PDFRenderer(doc);
int pageCount = doc.getNumberOfPages();
for (int i = 0; i < pageCount; i++) {
BufferedImage image = renderer.renderImageWithDPI(i, 240);
BufferedImage srcImage = resize(image, image.getWidth(), image.getHeight());
ImageIO.write(srcImage, "PNG", new File(pngPath.replace(".",i+".")));
}
} catch (IOException e) {
e.printStackTrace();
}
BufferedImage image = ImageIO.read(new FileInputStream(pngPath));
List<BufferedImage> images=new ArrayList<BufferedImage>();
BufferedImage srcImage = resize(image, image.getWidth(), image.getHeight());
images.add(srcImage);
//合成图片转pdf
createPDFFromImage(pdfPath,images);
java生成pdf,支持中文编码
Document document = createDoc(filename);
// 打开文档
document.open();
// 文档里写入
Paragraph centerPar = convertParToChinese("艳辉网", 20, bold, red);
centerPar.setAlignment(Element.ALIGN_CENTER); document.add(centerPar);
// document.add(new Paragraph("\n"));
// document.add(convertParToChinese("黑色", 18, boldItalic, black));
document.add(new Paragraph("\n"));
document.add(convertParToChinese("你最爱上的艳辉博客,加QQ群494808400,即可获取更多java资料。", 12, normal, black));
document.add(new Paragraph("\n"));
// 文档写入图片
if (checkFile(imgPath)) {
Image image = writeImg(imgPath);
document.add(image);
document.add(new Paragraph("\n"));
}
// document.add(new Paragraph("\n"));
// // 生成三列表格
// PdfPTable table = new PdfPTable(3);
// // 设置表格具体宽度
// table.setTotalWidth(90);
// // 设置每一列所占的长度
// table.setWidths(new float[] { 50f, 15f, 25f });
// PdfPCell cell1 = new PdfPCell();
// Paragraph para = new Paragraph("aaaaa");
// cell1.setPhrase(para);
// table.addCell(cell1);
// table.addCell(new PdfPCell(new Phrase("IText")));
// table.addCell(new PdfPCell(new Phrase("IText")));
// document.add(table); // document.add(new Paragraph("\n"));
// document.add(new Paragraph("\n"));
// PDF同行显示
// Paragraph par = new Paragraph();
// Chunk chunk1 = new Chunk( convertChunkByChinese("考试分数:", 20, bold, black));
// Chunk chunk2 = new Chunk(convertChunkByChinese("93", 20, bold, red));
// par.add(chunk1);
// par.add(chunk2);
// // 设置整体缩进
// par.setFirstLineIndent(setting);
// // 居中
// Paragraph centerPar = convertParToChinese("剧中测试", 16, italic, black);
// centerPar.setAlignment(Element.ALIGN_CENTER);
// document.add(par);
// 新建章节
// 章节标题
// Paragraph chapterTitle = new Paragraph(convertParToChinese("章节标题", 18, boldItalic, blue));
// Chapter chapter1 = new Chapter(chapterTitle, 1);
// chapter1.setNumberDepth(0);
// Paragraph p = new Paragraph("test!!!!!");
// chapter1.add(p);
// document.add(chapter1); //关闭文档
document.close();
还有pdf2word2.0
PDDocument doc=PDDocument.load(new File(name1));
int pagenumber=doc.getNumberOfPages(); name1 = name1.substring(0, name1.lastIndexOf("."));
// String dirName = "D:\\pdf\\";// 创建目录D:\\pdf\\a.doc
String dirName = name1;// 创建目录D:\\pdf\\a.doc
//createDir(dirName);// 调用方法创建目录
String fileName = dirName + ".doc";// 创建文件
createFile(fileName);
FileOutputStream fos=new FileOutputStream(fileName);
Writer writer=new OutputStreamWriter(fos,"UTF-8");
PDFTextStripper stripper=new PDFTextStripper(); // doc.addSignature(arg0, arg1, arg2); stripper.setSortByPosition(true);//排序
//stripper.setWordSeparator("");//pdfbox对中文默认是用空格分隔每一个字,通过这个语句消除空格(视频是这么说的)
stripper.setStartPage(1);//设置转换的开始页
stripper.setEndPage(pagenumber);//设置转换的结束页
stripper.writeText(doc,writer);
writer.close();
doc.close();
System.out.println("pdf转换word成功!");
三:java-pdf转word3.0
注:原文来源 《 java-pdf转word3.0 》
java-pdf转word3.0
2.0是pdf转图片,现在出3.0图片再转成word,写1.0的时候目的是使用pdfbox.jar将pdf文件转成word文件,在wps中转的话需要充会员,如果使用java的话,只需要配置环境,大大节省了一笔money,渐渐大部分很多做java的都需要写这个需求,有的我加了别人,别人不提供源代码,只说了方法,但是我也很感激。。。有很多人加我QQ,就说我这个那个pdf转word能不能实现,说我没提供代码是不是骗子什么的,对于这个pdf转word要求保留样式,保留图片,,别人wps转也需要收钱的,他们开发不一定是用java开发的,你也可以用C++开发一个,这里pdf转word这个需求只是简单的实现文字转换,当然你也可以加QQ一起讨论,以后会出4.0 5.0 5.2 。。。版本的。说了很多煽情的话,是时候展现正真的技术了。
首先分享pdf转html:
这是小编在网上copy下来的,先整个下载pdf2htmlEX-v1.0文件夹
pdf2html("D:\\DesignSoftware\\pdf\\pdf2htmlEX-v1.0\\pdf2htmlEX.exe",
"D:\\a.pdf",
"D:\\HTMLPDF","a1.html");
意思是将D盘的a.pdf转成a1.html并保存在D盘HTMLPDF目录中。
然后分享的是html转word:
也是百度下来的
new Html2Doc().writeWordFile("D:/a3.html","D:/test222.doc",1);
意思是将D盘的a3.html转成test222.doc并保存在D盘目录中。
其中1表示本地html 2表示在线 在线并没有开放,我测试了在线的转成doc后样式全丢失,就像感觉怀疑人生。。。
本章博客的代码全部公开免费,因为大部分代码都是东拼西凑下来完成需求的,但是1.0和2.0的代码需要开通我们艳辉vip才能获取。
这样你的需求就能实现pdf转word时,只要pdf读取出图片,然后再将图片写入word文档,就能实现pdf转word保存图片的效果。然后有人就会问,保存图片却不能编辑,有毛线用啊。
所以可以看看2.0的,pdf转word时,我们先做一个word模板,然后再将数据填进去,这样word就能实现编辑效果,缺点就是要有固定的模板,变化能力差。想到更好的方法可留言。喷我也可留言,反正被喷都不是第一次,这部分代码可以免费下载,可以加QQ490647751,回复java-pdf转word3.0,即可获取代码学习。
小编想了pdf转html,html再转word,但是html转word样式和图片也丢失,无奈放弃。。。
java-pdf转word的更多相关文章
- java PDF转word的初步实现
package com.springboot.springboot.util; import java.io.File; import java.io.FileOutputStream; import ...
- java pdf转word 高效不失真
将java工程导成jar包 使用 bat 执行 jar 包. --------------------------------------------------------------------- ...
- Java解析OFFICE(word,excel,powerpoint)以及PDF的实现方案及开发中的点滴分享
Java解析OFFICE(word,excel,powerpoint)以及PDF的实现方案及开发中的点滴分享 在此,先分享下写此文前的经历与感受,我所有的感觉浓缩到一个字,那就是:"坑&qu ...
- Java 将PDF 转为Word、图片、SVG、XPS、Html、PDF/A
本文将介绍通过Java编程来实现PDF文档转换的方法.包括: 1. PDF转为Word 2. PDF转为图片 3. PDF转为Html 4. PDF转为SVG 4.1 将PDF每一页转为单个的SVG ...
- iText导出pdf、word、图片
一.前言 在企业的信息系统中,报表处理一直占比较重要的作用,本文将介绍一种生成PDF报表的Java组件--iText.通过在服务器端使用Jsp或JavaBean生成PDF报表,客户端采用超级连接显示或 ...
- java 如何将 word,excel,ppt如何转pdf--jacob
问题:java 如果将 word,excel,ppt如何转pdf 我个人的观点:windows server下用 jacob; linux server下 用openoffice. PS:1.本文 ...
- CAJ Viewer安装流程以及CAJ或Pdf转换为Word格式
不多说,直接上干货! pdf转word格式,最简单的就是,实用工具 Adobe Acrobat DC 首先声明的是,将CAJ或者Pdf转换成Word文档,包括里面的文字.图片以及格式,根本不需 ...
- 基于DevExpress实现对PDF、Word、Excel文档的预览及操作处理
http://www.cnblogs.com/wuhuacong/p/4175266.html 在一般的管理系统模块里面,越来越多的设计到一些常用文档的上传保存操作,其中如PDF.Word.Excel ...
- 一款免费支持PDF、word、excel、PPT、jpeg之间互转线上软件
偶然发现的一款免费支持PDF.word.excel.PPT.jpeg之间互转,支持合并pdf.加密解密PDF的线上软件,首先声明,不是广告党,我自己试用过,确实是目前我用过最好用的,如果有朋友有更好的 ...
- pdf转word
一.刚需 pdf转word,这个需求肯定是有的.但是大家都知道,pdf是用来排版打印的,所以编辑起来会比较麻烦,所以,大家都会尝试将pdf的内容转成word,然后再进行编辑. 二.方法 1.用offi ...
随机推荐
- oracle rman备份
rman 登录到cmd 打开cmd 输入 rman connect target jhpt/1@orcl C:\Documents and Settings\Administrator>rman ...
- CMD之入门篇
本博文最早是记录在本地电脑的,由于清理电脑的缘故,顺便将这篇笔记转移到公共博客,以便日后查阅和快速上手使用. 开门见山,步入正题,以下是Windows系统的常用CMD命令. 一 文件系统操作 0.[脚 ...
- Javascript入门(四)条件控制语句
一.条件控制语句 1. if <script type="text/javascript"> var num = 1 if( num == 3 ){ alert(&qu ...
- (7)Java数据结构--集合map,set,list详解
MAP,SET,LIST,等JAVA中集合解析(了解) - clam_clam的专栏 - CSDN博---有颜色, http://blog.csdn.net/clam_clam/article/det ...
- Struts2-052 漏洞复现
s2-052漏洞复现 参考链接: http://www.freebuf.com/vuls/147017.html http://www.freebuf.com/vuls/146718.html 漏洞描 ...
- python - 爬虫入门练习 爬取链家网二手房信息
import requests from bs4 import BeautifulSoup import sqlite3 conn = sqlite3.connect("test.db&qu ...
- html转成pdf,下载(html2canvas 和 jsPDF)
参考链接:https://github.com/linwalker/render-html-to-pdf
- shellb编程 之 实践出真知
1.查询file1 里面空行的所在行号 纯空行:awk ‘{if($0~/^$/)print NR}’ file 空行和带空格,制表符等的行:awk '$0~/^\s*$/' file 2.查询fil ...
- P4070 [SDOI2016]生成魔咒
题目地址:P4070 [SDOI2016]生成魔咒 相信看到题目之后很多人跟我的思路是一样的-- 肯定要用 SA(P3809 [模板]后缀排序) 肯定要会求本质不同的子串个数(P2408 不同子串个数 ...
- (转)如何用TensorLayer做目标检测的数据增强
数据增强在机器学习中的作用不言而喻.和图片分类的数据增强不同,训练目标检测模型的数据增强在对图像做处理时,还需要对图片中每个目标的坐标做相应的处理.此外,位移.裁剪等操作还有可能使得一些目标在处理后只 ...