您好,登錄后才能下訂單哦!
這篇文章主要介紹“Java怎么實現pdf和Excel的生成及數據動態插入與導出”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Java怎么實現pdf和Excel的生成及數據動態插入與導出”文章能幫助大家解決問題。
Excel、PDF的導出、導入是我們工作中經常遇到的一個問題,剛好今天公司業務遇到了這個問題,順便記個筆記以防下次遇到相同的問題而束手無策。
公司有這么兩個需求:
需求一、給了一個表單,讓把查出來的數據組裝到表單中并且提供以PDF格式的下載功能。
需求二、將數據查出來以Excel表格的形式下載下來。
因為 PDF 常用的軟件不讓支持編輯,我們就先使用 WPS 以 Word 的形式進行編輯制作出與客戶需求一樣的樣式,然后直接另存為 .pdf 的形式
b.更改名字為 .pdf形式
c.這時需要用到一個叫:Adobe Acrobat DC 的軟件,具體操作如下:
用 Adobe Acrobat DC 打開我們剛才改過名字的 PDF 文件,點擊右下角的“更多工具”按鈕
到下面這個頁面再點擊“準備表單”按鈕
d.接下來就需要詳細的配置你的數據源了
數據源即:你代碼中實體類中對應的數據(注意字段一定要一一對應),配置完畢就可以保存進行下面的代碼編寫工作了。
假定我們實體類什么的都已經編寫完成、數據通過前端傳入獲取、模板位置在E盤根目錄下名字為:車輛維修審批單.pdf
導入 jar 包:
<!-- PDF導出-->
<!-- https://mvnrepository.com/artifact/com.itextpdf/itextpdf -->
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.13</version>
</dependency>
實現生成 PDF、數據插入、導出
@RegisterToSMP(serviceDisplay = "預覽頁面PDF下載")
@RequestMapping(value = "/DM/gwclwxsq/qygl/exportPDF$m=query.service",method =RequestMethod.POST)
public String exportPdf(@RequestBody GwclwxsqBean gwclwxsqBean , HttpServletResponse response) throws UnsupportedEncodingException {
// 1.指定解析器
System.setProperty("javax.xml.parsers.DocumentBuilderFactory",
"com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderFactoryImpl");
String filename="車輛維修審批單.pdf";
String path="e:/";
response.setContentType("application/pdf");
response.setHeader("Content-Disposition", "attachment;fileName="
+ URLEncoder.encode(filename, "UTF-8"));
OutputStream os = null;
PdfStamper ps = null;
PdfReader reader = null;
try {
os = response.getOutputStream();
// 2 讀入pdf表單
reader = new PdfReader(path+ "/"+filename);
// 3 根據表單生成一個新的pdf
ps = new PdfStamper(reader, os);
// 4 獲取pdf表單
AcroFields form = ps.getAcroFields();
// 5給表單添加中文字體 這里采用系統字體。不設置的話,中文可能無法顯示
BaseFont bf = BaseFont.createFont("C:/WINDOWS/Fonts/SIMSUN.TTC,1",
BaseFont.IDENTITY_H, BaseFont.EMBEDDED);
form.addSubstitutionFont(bf);
// 6查詢數據================================================
Map<String, String> data = new HashMap<String, String>();
data.put("commitTime", gwclwxsqBean.getCommitTime());
data.put("driver", gwclwxsqBean.getDriver());
data.put("carId", gwclwxsqBean.getCarId());
data.put("carType", gwclwxsqBean.getCarType());
data.put("repairAddress", gwclwxsqBean.getRepairAddress());
data.put("repairCost",gwclwxsqBean.getRepairCost());
data.put("project", gwclwxsqBean.getProject());
data.put("fwbzzxfzrYj", gwclwxsqBean.getFwbzzxfzrYj());
data.put("fgldspYj", gwclwxsqBean.getFgldspYj());
data.put("remarks", gwclwxsqBean.getRemarks());
// 7遍歷data 給pdf表單表格賦值
for (String key : data.keySet()) {
form.setField(key,data.get(key).toString());
}
ps.setFormFlattening(true);
log.info("*******************PDF導出成功***********************");
} catch (Exception e) { log.error("*******************PDF導出失敗***********************");
e.printStackTrace();
} finally {
try {
ps.close();
reader.close();
os.close();
} catch (Exception e) {
e.printStackTrace();
}
}
return null;
}
這個比較簡單,直接上代碼(假定你的實體類、查詢什么的都已經寫好)注意:實體類一個是你自己的數據實體類還有一個是你導出時表格中對應的實體類。100道 Java中高級面試題匯總
我們以一個真實的公司業務來舉個例子(一個統計疫情登記人員信息的Excel導出功能)
a.表頭對應實體類 ExportYqfkdj.java
import lombok.Data;
/**
* description:
* @author: zhouhong
* @version: V1.0.0
* @date: 2021年1月14日 下午3:05:54
*/
@Data
public class ExportYqfkdj {
/**
* 序號
*/
private Integer xuhao;
/**
* 姓名
*/
private String xingming;
/**
* 證件號碼
*/
private String zjhm;
/**
* 聯系電話
*/
private String lxdh;
/**
* 申請人工作單位
*/
private String sqrGzdw;
/**
* 是否接觸過疑似病例
*/
private String sfjcgysbl;
/**
* 當前是否與居家隔離人員同住
*/
private String sfyjjglrytz;
/**
* 當前狀態
*/
private String dqzt;
/**
* 當前健康狀態
*/
private String dqjkzt;
/**
* 當前體溫
*/
private String dqtw;
/**
* 當前所在地址
*/
private String dqszdz;
/**
* 當前居住地址
*/
private String dqjzdz;
/**
* 提交時間
* */
private String tjsj;
}
b.Service 層
/**
* 導出
* @param yqfkdjBean
* @author zhouhong
* @return
* @throws Exception
*/
@Transactional(rollbackFor = { Exception.class })
public DataResult exporYqfkdj(YqfkdjBean yqfkdjBean) throws Exception {
DataResult result = new DataResult();
List<ExportYqfkdj> list = new ArrayList<ExportYqfkdj>();
try {
/* 查詢導出信息 */
result = getYqfkMhCXQuery(yqfkdjBean);
SimpleDateFormat df = new SimpleDateFormat("yyyyMMddhhmmssSSS");
for (int i = 0; i < result.getTotalcount(); i++) {
ExportYqfkdj dmKhfwdcDtjlZxDto = new ExportYqfkdj();
dmKhfwdcDtjlZxDto = ObjectUtil.parsePojo(result.getResults().get(i), ExportYqfkdj.class);
dmKhfwdcDtjlZxDto.setXuhao(i + 1);
list.add(dmKhfwdcDtjlZxDto);
}
String filepath = "D:/疫情防控信息" + df.format(new Date()) + ".xlsx";
if (System.getProperty(YqfkdjUtils.Wjdz.NAME).toLowerCase().startsWith(YqfkdjUtils.Wjdz.LI)
|| System.getProperty(YqfkdjUtils.Wjdz.NAME).toLowerCase().startsWith(YqfkdjUtils.Wjdz.LIN)) {
filepath = "/home/Tomcat/temp/" + df.format(new Date()) + ".xlsx";
}
EasyExcel.write(filepath, ExportYqfkdj.class).head(head()).sheet().doWrite(list);
result.setResults(list);
result.setSuccess(true);
result.setMsg(filepath);
} catch (Exception e) {
result.setSuccess(false);
result.setMsg(YqfkdjUtils.Cytx.DCSB);
e.printStackTrace();
throw e;
}
return result;
}
/**
* 疫情防控信息導出表頭
* @author zhouhong
* @return List<List<String>>
*/
private List<List<String>> head() {
List<List<String>> list = new ArrayList<List<String>>();
List<String> head0 = new ArrayList<String>();
head0.add("序號");
List<String> head1 = new ArrayList<String>();
head1.add("姓名");
List<String> head2 = new ArrayList<String>();
head2.add("證件號碼");
List<String> head3 = new ArrayList<String>();
head3.add("聯系電話");
List<String> head4 = new ArrayList<String>();
head4.add("工作所在單位");
List<String> head5 = new ArrayList<String>();
head5.add("是否接觸疑似病例");
List<String> head6 = new ArrayList<String>();
head6.add("是否與隔離人員同住");
List<String> head7 = new ArrayList<String>();
head7.add("當前狀態");
List<String> head8 = new ArrayList<String>();
head8.add("當前健康狀態");
List<String> head9 = new ArrayList<String>();
head9.add("體溫(°C)");
List<String> head10 = new ArrayList<String>();
head10.add("當前所在地址");
List<String> head11 = new ArrayList<String>();
head11.add("當前居住地址");
List<String> head12 = new ArrayList<String>();
head12.add("提交時間");
list.add(head0);
list.add(head1);
list.add(head2);
list.add(head3);
list.add(head4);
list.add(head5);
list.add(head6);
list.add(head7);
list.add(head8);
list.add(head9);
list.add(head10);
list.add(head11);
list.add(head12);
return list;
}
@RegisterToSMP(serviceDisplay = "疫情防控查詢導出")
@RequestMapping(value = "/DM/yqfkdj/gr/yqfkdjdc$m=export.service", method = RequestMethod.POST)
public void exportKhfxxx(@RequestBody YqfkdjBean yqfkdjBean, HttpServletResponse resp) throws Exception {
DataResult result = new DataResult();
try {
SimpleDateFormat df = new SimpleDateFormat("yyyyMMddhhmmssSSS");
result = yqfkdjService.exporYqfkdj(yqfkdjBean);
String filepath = result.getMsg().replace("\"", "");
File file = new File(filepath);
String filename = "疫情防控信息" + df.format(new Date()) + ".xlsx";
InputStream fis = new BufferedInputStream(new FileInputStream(filepath));
byte[] buffer = new byte[fis.available()];
fis.read(buffer);
fis.close();
resp.reset();
resp.setHeader("Content-Disposition",
"attachment;filename=" + new String(filename.replaceAll(" ", "").getBytes("gbk")));
resp.setHeader("Content-Length", "" + file.length());
OutputStream os = new BufferedOutputStream(resp.getOutputStream());
resp.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
// 輸出文件
os.write(buffer);
os.flush();
os.close();
} catch (Exception e) {
e.printStackTrace();
log.info(YqfkdjUtils.Cytx.DCSB);
throw e;
}
}
關于“Java怎么實現pdf和Excel的生成及數據動態插入與導出”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。