//导出
public void ScoringAnnouncementdownLoad() throws MalformedURLException, IOException, DocumentException, FileStoreException {
ActionContext act = ActionContext.getContext();
AclUserBean logonUser = (AclUserBean) act.getSession().get(Constant.LOGON_USER);
String acnt=logonUser.getAcnt();
ResponseWrapper response = act.getResponse();
OutputStream os = null;
String fileName = "特约店综合评分.pdf";
fileName = new String(fileName.getBytes("GB2312"), "ISO8859-1");
Document document=new Document(PageSize.A0, 10, 10,10, 10);
Rectangle pageRect=document.getPageSize();
ByteArrayOutputStream baos = new ByteArrayOutputStream();
PdfWriter writer = PdfWriter.getInstance(document, baos);
Paragraph emptyLine10 = new Paragraph(10,"");
BaseFont bf= BaseFont.createFont("C:/WINDOWS/Fonts/SIMYOU.TTF", BaseFont.IDENTITY_H,BaseFont.NOT_EMBEDDED);
Font fontChinese10 = new Font(bf,10, Font.NORMAL);
//页尾
document.setFooter(createFooter(fontChinese10));
//页头
document.setHeader(createHeader(fontChinese10));
//水印
Watermark W =new Watermark(acnt);
writer.setPageEvent(W);
//打开
document.open();
//添加空行
document.add(emptyLine10);
//加数据
document.add(createTab(fontChinese10));
//创建新页
document.newPage();
//关闭
document.close();
//生成是否保存
response.addHeader("Content-Disposition", "attachment;filename=" + fileName);
response.setContentType("application/pdf");
response.setContentLength(baos.size());
os = response.getOutputStream();
baos.writeTo(os);
//关闭流
os.flush();
os.close();
}
private HeaderFooter createFooter(Font fontChinese10){
String footStr1 = "页尾 ";
HeaderFooter footer=new HeaderFooter(new Phrase(footStr1,fontChinese10),new Phrase(" \t\t",fontChinese10));
footer.setAlignment(Element.ALIGN_RIGHT);
footer.setBottom(0);
return footer;
}
private HeaderFooter createHeader(Font fontChinese10){
String footStr1 = "页头 ";
HeaderFooter footer=new HeaderFooter(new Phrase(footStr1,fontChinese10), false) ;
footer.setAlignment(Element.ALIGN_CENTER);
footer.setTop(0);
footer.setLeft(0);
return footer;
}
//数据
private PdfPTable createTab(Font fontChinese12){
try {
PdfPTable tab = new PdfPTable(27);//多少列
//tab.setTotalWidth(100); //固定宽度
tab.setWidths(new int[]{20,20,40,50,50,50,50,45,45,40,40,60,90,55,75,50,40,40,78,55,50,50,60,50,50,35,50}); //每列的宽度, 只针对固 定宽度有效;如果表格使用百分比设置总宽度的话,那这里也就是使用百分比.
tab.setWidthPercentage(100);// 表格宽度设置为100%
List<Map<String, Object>> data = tabData();
PdfPCell cell_temp = null;
cell_temp = new PdfPCell(new Paragraph("排名", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("大区", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("省份", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("特约店简称", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("特约店代码", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("开业时间", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("提车达成率12%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("登录达成率12%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("提车贡献率 10%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("市占率6%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("销售满意度6%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("客流目标达成率 6%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("电话网络到店目标达成率2%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("二手车目标达成率6%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("电话网络到店目标达成率2%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("售后满意度8%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("人员培训4%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("保养达成率8%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("管理内用户再次回店保养率4%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("保险产品 达成率8%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("用品单车产值4%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("保养单车达成率8%", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("售后有责投诉(扣分项)", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("售后得分", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("总分", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("是否参评", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph("取消参评原因", fontChinese12));
tab.addCell(cell_temp);
if(data!=null){
for (int i = 0; i < data.size(); i++) {
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("RANKING")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("REGION_NAME")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("PROVINCE")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("DEALER_SHORTNAME")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("DEALER_CODE")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("OPEN_DATE")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1001")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1002")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1003")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1004")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1005")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1006")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1007")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1008")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V1999")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2001")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2002")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2003")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2004")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2005")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2006")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2007")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2008")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V2999")+"", fontChinese12));
tab.addCell(cell_temp);
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("V9999")+"", fontChinese12));
tab.addCell(cell_temp);
if(data.get(i).get("IS_EVALUATING")=="10041002"){
cell_temp = new PdfPCell(new Paragraph("否", fontChinese12));
tab.addCell(cell_temp);
}else{
cell_temp = new PdfPCell(new Paragraph("是", fontChinese12));
tab.addCell(cell_temp);
}
cell_temp = new PdfPCell(new Paragraph(data.get(i).get("CANCEL_REASON")+"", fontChinese12));
tab.addCell(cell_temp);
}
}
return tab;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
private List<Map<String, Object>> tabData(){
String DEPT_NAME=CommonUtils.checkNull(reqUtil.getString("DEPT_NAME"));//区域
String DEALER_ID=CommonUtils.checkNull(reqUtil.getString("DEALER_ID"));//店代码
String DEALER_NAME=CommonUtils.checkNull(reqUtil.getString("DEALER_NAME"));//店简称
String year = CommonUtils.checkNull(reqUtil.getString("year"));//年度
String monthBegin = CommonUtils.checkNull(reqUtil.getString("monthBegin"));//月份
Map<String, String> passMap = new HashMap<String, String>();
passMap.put("DEPT_NAME", DEPT_NAME);
passMap.put("DEALER_ID", DEALER_ID);
passMap.put("year", year);
passMap.put("DEALER_NAME", DEALER_NAME);
passMap.put("monthBegin", monthBegin);
PageResult<Map<String, Object>> ps = dao.assessmentRangeSearch(passMap, Constant.PAGE_SIZE_ALL, 1);
List<Map<String, Object>> records = ps.getRecords();
return records;
}
//水印
public class Watermark extends PdfPageEventHelper {
Font FONT = new Font("",24, Font.BOLD, new GrayColor(0.75f));
private String waterCont;//水印内容
public Watermark() {
}
public Watermark(String waterCont) {
this.waterCont = waterCont;
}
@Override
public void onEndPage(PdfWriter writer, Document document) {
for(int i=0 ; i<20; i++) {
for(int j=0; j<28; j++) {
ColumnText.showTextAligned(writer.getDirectContentUnder(),
Element.ALIGN_CENTER,
new Phrase(this.waterCont == null ? "HELLO WORLD" : this.waterCont, FONT),
(50.5f+i*180),
(40.0f+j*130),
writer.getPageNumber() % 2 == 1 ? 45 : -45);
}
}
}
}
- JAVA导出pdf实例
一.直接导出成PDF Java代码 1. import java.io.FileNotFoundException; 2. import java.io.FileOutputStream; 3. ...
- java导出pdf功能记录
这几天已在做处理导出pdf文件的功能,摸索了几天总算可以了.记录下这几天遇到的问题. 1.网上基本都是基于Itext5和Itext7来处理的.我最终是在Itext5上成功了,itext7应该是模板出问 ...
- Java导出Pdf格式表单
前言 作为开发人员,工作中难免会遇到复杂表单的导出,接下来介绍一种通过Java利用模板便捷导出Pdf表单的方式 模拟需求 需求:按照下面格式导出pdf格式的学生成绩单 准备工作 Excel软件 ...
- Java导出pdf文件数据
提示:导出pdf文件,需要3个jar包iText-2.1.5.jar,iTextAsian.jar,iText-rtf-2.1.4.jar. public boolean outputPdfJhsy( ...
- 一次java导出pdf的经历
近期由于工作需要,需要将html代码导入到pdf中,经过了几种pdf的方案对比后发现IText是最简单和便捷的一种方式,于是乎采用了Itext. PDF生成 第一步:导入Maven依赖 <!-- ...
- java根据模板导出PDF详细教程
原文:https://blog.csdn.net/pengyufight/article/details/75305128 题记:由于业务的需要,需要根据模板定制pdf文档,经测试根据模板导出word ...
- java根据模板导出pdf
在网上看了一些Java生成pdf文件的,写的有点乱,有的不支持写入中文字体,有的不支持模板,有的只是随便把数据放里面生成文件,完全不考虑数据怎样放置的以及以后的维护性,想想还是自己总结一个完全版的导出 ...
- java利用itext导出pdf
项目中有一功能是导出历史记录,可以导出pdf和excel,这里先说导出pdf.在网上查可以用那些方式导出pdf,用itext比较多广泛. 导出pdf可以使用两种方式,一是可以根据已有的pdf模板,进行 ...
- java根据模板文件导出pdf
原文:https://www.cnblogs.com/wangpeng00700/p/8418594.html 在网上看了一些Java生成pdf文件的,写的有点乱,有的不支持写入中文字体,有的不支持模 ...
随机推荐
- react项目中实现悬浮(hover)在按钮上时在旁边显示提示
<i className={classNames({ 'device-icon': true, 'camera-icon': true, 'camera-icon-hover-show-intr ...
- 自定义 Cordova插件(基础篇)
cordova自定义插件 注意:存放自定义cordova插件目录不能有空格可能会报错 cordova的安装 下载node.js,安装完成后你可以在命令行中使用node和npm. 安装cordova使用 ...
- es6 Promise简单介绍
promise的基本用法 promise执行多步操作非常好用,那我们就来模仿一个多步操作的过程,那就以吃饭为例吧.要想在家吃顿饭,是要经过三个步骤的. 洗菜做饭. 坐下来吃饭. 收拾桌子洗碗. 这个过 ...
- PYTHON -- 基础3
1.数据类型 1.int 类型 用于计算 1.1 bit_length() 转换为2进制的最小位置 有效的 i = 5 print(i.bit_length()) i 二进制 i.bit_length ...
- Mac OS X 操作系统下IntelliJ IDEA激活码(Activation code)破解
Mac OS X 操作系统(版本:10.13.6)下载并安装IntelliJ IDEA: Version: 2018.2.4 Download IntelliJ IDEA 下一步对IntelliJ I ...
- Java开源框架知识整理
1.Spring的了解 Spring是一个轻量级的IOC/DI和AOP容器的开源框架.可以实现Java模块化开发,贯穿表现层,业务层,逻辑层,实现各层之间的解耦合关系. IOC,控制反 ...
- 使用logstash同步mysql数据到elasticsearch
下载 logstash tar -zxvf https://artifacts.elastic.co/downloads/logstash/logstash-6.3.2.tar.gz .tar.gz ...
- mysql innodb 唯一键里的字段为什么不能为NULL
mysql 唯一键失效 CREATE TABLE `studnet_unique` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(100 ...
- 在学习JavaScript中用到的示例
jQuery老师博客 一.定时器示例 功能:让input的文本框,显示时间,并实时更新 逻辑思路: 1.先定义一个函数,用来把当前时间赋值给input.value 2.开始button设置点击事件,并 ...
- Angular2+ 编译后部署到服务器上页面刷新404问题
原因:NG2+ 会默认不显示URL后面的文件名 解决方案:使用LocationStrategy方式,然后把URL后的# 替换成index.html# app.module.ts import {Has ...