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 ...
随机推荐
- 小程序开发 从简单的 crud 开始
关键字:“小程序 API” [WXML 完成布局] <view> == <div> {{}} == <%= %> ejs | jsp2 <block wx: ...
- 结构体类型struct
教学视频 定义: struct student{CString name; int num; TCHAR sex; int age; }; //注意有个分号 student zansan = {_ ...
- vue安装教程总结
转载:https://blog.csdn.net/sunny1660/article/details/78326548 简介: vue.js是一套构建用户界面的渐进式框架.比较简洁,用于解 ...
- 将sublime添加到鼠标右键
1.win+R 输入regedit ,打开注册表. 2.找到HKEY_CLASSES_ROOT/*/shell目录,在此目录下 ①新建项,命名为“sublime Text”(也可以是其他名字),双击右 ...
- 如何快速上手一个新技术之vue学习经验
碰到紧急项目挪别人的vue项目过来直接改,但是vue是18年初看过一遍,18年底再来用,早就忘到九霄云外了,结果丢脸的从打开vue开始学,虽然之前在有道云笔记做了很多记录,然后没有系统整理.所以借这次 ...
- modbus 寄存器介绍
modbus 的查询命令 命令 地址开始(两个地址) 地址长度(两个地址) 检验 01 xx xx xx ...
- Jquery中AJAX参数详细(1)-转
http://www.cnblogs.com/qiufuwu618/archive/2012/12/20/2826190.html Jquery中AJAX参数详细列表: 参数名 类型 描述 url S ...
- nova 命令管理虚拟机
nova命令管理虚拟机: $ nova list #查看虚拟机$ nova stop [vm-name]或[vm-id] #关闭虚拟机$ nova start [vm-name]或[vm-id] #启 ...
- oracle查询语句 select a||','||b||','||c from table where a in('m','n')
查询table表中 字段a = m 或 n 时,a列,b列,c列的值,并且这三列之间用 ","(逗号)分割. 追问:连接符的作用呢?就是显示的时候链接abc和中间的逗号么?追答:| ...
- 记一次手动SQL注入
1.检测到可能存在注入漏洞的url 最常用的 ' ,and 1=1 ,and 1=2 http://www.xxx.com/subcat.php?id=1 2.判断字段个数 http://www.xx ...