java在pdf中生成表格的方法

1、目标

  在pdf中生成一个可变表头的表格,并向其中填充数据。通过泛型动态的生成表头,通过反射动态获取实体类(我这里是User)的get方法动态获得数据,从而达到动态生成表格。

  每天生成一个文件夹存储生成的pdf文件(文件夹的命名是年月日时间戳),如:20151110

  生成的文件可能在毫秒级别,故文件的命名规则是"到毫秒的时间戳-uuid",如:20151110100245690-ece540e5-7737-4ab7-b2d6-87bc23917c8c.pdf

  通过读取properties文件动态获取文件存储的跟目录。

2、所需的jar

  这里通过itex插件进行pdf的生成,需要的jar包括以下几个

3、编码实现

1)、实体类

package com.zcr.until;

public class User
{
 private String name;
 private int age ;
 private float height;
 private String adress;
 private String sex;
 private String jj;

 public String getJj()
 {
 return jj;
 }

 public void setJj(String jj)
 {
 this.jj = jj;
 }

 public User()
 {

 }

 public User(String name,int age,float height,String adress,String sex,String jj)
 {
 this.name = name;
 this.age = age;
 this.height = height;
 this.adress = adress;
 this.sex = sex;
 this.jj = jj;
 }

 public String getAdress()
 {
 return adress;
 }

 public void setAdress(String adress)
 {
 this.adress = adress;
 }

 public String getSex()
 {
 return sex;
 }

 public void setSex(String sex)
 {
 this.sex = sex;
 }

 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
 public int getAge() {
 return age;
 }
 public void setAge(int age) {
 this.age = age;
 }
 public float getHeight() {
 return height;
 }
 public void setHeight(float height) {
 this.height = height;
 }

}

2)、properties文件

pdfPath=E\:/appDataPdf
3)、读取properties文件,获取pdf存储的路径

package com.zcr.until;

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

public class GetFilePlace
{
 /**
 * 读取文件,获取excel保存的根目录
 * @return excel保存的根目录
 */
 public String getFilePath()
 {
 String dir = System.getProperty("user.dir"); //获得tomcat所在的工作路径 

 //获取到存储了文件存储位置的filedir.properties 文件路径 --->java Project的文件路径
 String realDir = dir + File.separator + "src" + File.separator +"META-INF" + File.separator + "filedir.properties";

     //Web project存储路径
 /*String realDir = dir.substring(0, dir.length()-4) + File.separator +"webapps" + File.separator + "generateExcels"
   + File.separator + "classes" + File.separator + "META-INF" + File.separator + "config" + File.separator + "filedir.properties";
 */
 return realDir;
 }

 /**
 * 获取filePath路径【properities文件】中key对应的值,
 * @param filePath properities文件路径【包含properities文件】
 * @param key 要查找的key值
 * @return key对应的value
 */
 public String GetValueByKey(String filePath, String key)
 {
  Properties pps = new Properties();
  try {
  InputStream in = new BufferedInputStream (new FileInputStream(filePath));
  pps.load(in);
  String value = pps.getProperty(key);
  in.close();
  return value;

  }catch (IOException e) {
  e.printStackTrace();
  return null;
  }
 }

 /**
 * 查询properities文件中可以对应的存储地点
 * @param key 查询主键
 * @return key对应的存储地址
 */
 public String getFileDirFromProperties(String key)
 {
 return GetValueByKey(getFilePath(),key);
 }

}

4)、获取当天存在的文件路径,不存在则生成一个新的文件夹

package com.zcr.service;

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Calendar;

public class GenerateFold
{
 /**
 * 查询当前生成的excel需要存在在哪个路径,如果存在则存储在相应的位置,否则生成改目录, 每天生成一个文件夹,文件夹的命名规则为 年月日的时间戳
 * @param foldName 生成excel保存路径
 * @return  现在的excel需要保存路径
 */
 public String getFold(String foldName)
 {
 SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd");

 String todayStr = format.format(Calendar.getInstance().getTime());

 String foldPath = foldName + File.separator + todayStr; 

 File file = new File(foldPath);

 if(!file.exists() && !file.isDirectory())
 {
  System.out.println("不存在");
  file.mkdirs();
 }
 else
 {
  System.out.println("存在");
 }
 return foldPath;
 }

}

5)、生成文件的名字

package com.zcr.until;

import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.UUID;

/**
 * 生成文件名字
 * @author zcr
 *
 */
public class GenerateFileName
{
 /**
 * 根据文件类别生成文件的名字,文件的命名规则是:文件目录/生成时间-uuid(全球唯一编码).文件类别
 * @param fileDir 文件的存储路径
 * @param fileType 文件的类别
 * @return   文件的名字
 */
 public String generateFileName(String fileDir,String fileType)
 {
 String saveFileName = "";
 SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmssSS");
 saveFileName += format.format(Calendar.getInstance().getTime());

 UUID uuid = UUID.randomUUID(); //全球唯一编码

 saveFileName += "-" + uuid.toString();
 saveFileName += "." + fileType;

 saveFileName = fileDir + File.separator + saveFileName;

 return saveFileName;
 }
}

6)、生成pdf

package com.zcr.service;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;

import com.lowagie.text.Document;
import com.lowagie.text.DocumentException;
import com.lowagie.text.Element;
import com.lowagie.text.Font;
import com.lowagie.text.PageSize;
import com.lowagie.text.Phrase;
import com.lowagie.text.pdf.BaseFont;
import com.lowagie.text.pdf.PdfPCell;
import com.lowagie.text.pdf.PdfPTable;
import com.lowagie.text.pdf.PdfWriter;
import com.zcr.until.GenerateFileName;
import com.zcr.until.GetFilePlace;
import com.zcr.until.User;

/**
 * 生成pdf
 * @author zcr
 *
 */
public class CreatePdf
{
 Document document = new Document();// 建立一个Document对象

 private static Font headfont;// 设置字体大小
 private static Font keyfont;// 设置字体大小
 private static Font textfont;// 设置字体大小

 static
 {
 //中文格式
 BaseFont bfChinese;
 try
 {
  // 设置中文显示
  bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H",BaseFont.NOT_EMBEDDED);
  headfont = new Font(bfChinese, 10, Font.BOLD);// 设置字体大小
  keyfont = new Font(bfChinese, 8, Font.BOLD);// 设置字体大小
  textfont = new Font(bfChinese, 8, Font.NORMAL);// 设置字体大小
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }

 /**
 * 文成文件
 * @param file 待生成的文件名
 */
 public CreatePdf(File file)
 {
 document.setPageSize(PageSize.A4);// 设置页面大小
 try
 {
  PdfWriter.getInstance(document, new FileOutputStream(file));
  document.open();
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }

 public CreatePdf()
 {

 }

 public void initFile(File file)
 {
 document.setPageSize(PageSize.A4);// 设置页面大小
 try
 {
  PdfWriter.getInstance(document, new FileOutputStream(file));
  document.open();
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }

 int maxWidth = 520;

 /**
 * 为表格添加一个内容
 * @param value  值
 * @param font  字体
 * @param align  对齐方式
 * @return  添加的文本框
 */
 public PdfPCell createCell(String value, Font font, int align)
 {
 PdfPCell cell = new PdfPCell();
 cell.setVerticalAlignment(Element.ALIGN_MIDDLE);
 cell.setHorizontalAlignment(align);
 cell.setPhrase(new Phrase(value, font));
 return cell;
 }

 /**
 * 为表格添加一个内容
 * @param value  值
 * @param font  字体
 * @return  添加的文本框
 */
 public PdfPCell createCell(String value, Font font)
 {
 PdfPCell cell = new PdfPCell();
 cell.setVerticalAlignment(Element.ALIGN_MIDDLE);
 cell.setHorizontalAlignment(Element.ALIGN_CENTER);
 cell.setPhrase(new Phrase(value, font));
 return cell;
 }

 /**
 * 为表格添加一个内容
 * @param value  值
 * @param font  字体
 * @param align  对齐方式
 * @param colspan 占多少列
 * @return  添加的文本框
 */
 public PdfPCell createCell(String value, Font font, int align, int colspan)
 {
 PdfPCell cell = new PdfPCell();
 cell.setVerticalAlignment(Element.ALIGN_MIDDLE);
 cell.setHorizontalAlignment(align);
 cell.setColspan(colspan);
 cell.setPhrase(new Phrase(value, font));
 return cell;
 }

 /**
 * 为表格添加一个内容
 * @param value  值
 * @param font  字体
 * @param align  对齐方式
 * @param colspan 占多少列
 * @param boderFlag 是否有有边框
 * @return  添加的文本框
 */
 public PdfPCell createCell(String value, Font font, int align, int colspan,
  boolean boderFlag)
 {
 PdfPCell cell = new PdfPCell();
 cell.setVerticalAlignment(Element.ALIGN_MIDDLE);
 cell.setHorizontalAlignment(align);
 cell.setColspan(colspan);
 cell.setPhrase(new Phrase(value, font));
 cell.setPadding(3.0f);
 if (!boderFlag)
 {
  cell.setBorder(0);
  cell.setPaddingTop(15.0f);
  cell.setPaddingBottom(8.0f);
 }
 return cell;
 }

 /**
 * 创建一个表格对象
 * @param colNumber 表格的列数
 * @return  生成的表格对象
 */
 public PdfPTable createTable(int colNumber)
 {
 PdfPTable table = new PdfPTable(colNumber);
 try
 {
  table.setTotalWidth(maxWidth);
  table.setLockedWidth(true);
  table.setHorizontalAlignment(Element.ALIGN_CENTER);
  table.getDefaultCell().setBorder(1);
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 return table;
 }

 public PdfPTable createTable(float[] widths)
 {
 PdfPTable table = new PdfPTable(widths);
 try
 {
  table.setTotalWidth(maxWidth);
  table.setLockedWidth(true);
  table.setHorizontalAlignment(Element.ALIGN_CENTER);
  table.getDefaultCell().setBorder(1);
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 return table;
 }

 public PdfPTable createBlankTable()
 {
 PdfPTable table = new PdfPTable(1);
 table.getDefaultCell().setBorder(0);
 table.addCell(createCell("", keyfont));
 table.setSpacingAfter(20.0f);
 table.setSpacingBefore(20.0f);
 return table;
 }

 public <T> void generatePDF(String [] head,List<T> list,int colNum)
 {
 Class classType = list.get(0).getClass();

 // 创建一个只有5列的表格
 PdfPTable table = createTable(colNum);

 // 添加备注,靠左,不显示边框
 table.addCell(createCell("APP信息列表:", keyfont, Element.ALIGN_LEFT, colNum,false));

 //设置表头
 for(int i = 0 ; i < colNum ; i++)
 {
  table.addCell(createCell(head[i], keyfont, Element.ALIGN_CENTER));
 }

 if(null != list && list.size() > 0)
 {
  int size = list.size();
  for(int i = 0 ; i < size ; i++)
  {
  T t = list.get(i);
  for(int j = 0 ; j < colNum ; j ++)
  {
   //获得首字母
   String firstLetter = head[j].substring(0,1).toUpperCase(); 

   //获得get方法,getName,getAge等
   String getMethodName = "get" + firstLetter + head[j].substring(1);

   Method method;
   try
   {
   //通过反射获得相应的get方法,用于获得相应的属性值
   method = classType.getMethod(getMethodName, new Class[]{});
   try
   {
    System.out.print(getMethodName +":" + method.invoke(t, new Class[]{}) +",");
    //添加数据
    table.addCell(createCell(method.invoke(t, new Class[]{}).toString(), textfont));
   }
   catch (IllegalArgumentException e)
   {
    e.printStackTrace();
   }
   catch (IllegalAccessException e)
   {
    e.printStackTrace();
   }
   catch (InvocationTargetException e)
   {
    e.printStackTrace();
   }
   }
   catch (SecurityException e)
   {
   e.printStackTrace();
   }
   catch (NoSuchMethodException e)
   {
   e.printStackTrace();
   }
  }

  System.out.println("");
  }
 }

 try
 {
  //将表格添加到文档中
  document.add(table);
 }
 catch (DocumentException e)
 {
  e.printStackTrace();
 }

 //关闭流
 document.close();
 }

 /**
 * 提供外界调用的接口,生成以head为表头,list为数据的pdf
 * @param head //数据表头
 * @param list //数据
 * @return //excel所在的路径
 */
 public <T> String generatePDFs(String [] head,List<T> list)
 {
 final String FilePath = "pdfPath";
 String saveFilePathAndName = "";

 //获得存储的根目录
 String savePath = new GetFilePlace().getFileDirFromProperties(FilePath);

 //获得当天存储的路径,不存在则生成当天的文件夹
 String realSavePath = new GenerateFold().getFold(savePath);

 saveFilePathAndName = new GenerateFileName().generateFileName(realSavePath,"pdf");

 File file = new File(saveFilePathAndName);
 try
 {
  file.createNewFile();
 }
 catch (IOException e1)
 {
  // TODO Auto-generated catch block
  e1.printStackTrace();
 }
  initFile(file);
 try
 {
  file.createNewFile(); //生成一个pdf文件
 }
 catch (IOException e)
 {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 new CreatePdf(file).generatePDF(head,list,head.length);

 return saveFilePathAndName;
 }

}

7)、测评函数

 public static void main(String[] args)
 {
 System.out.println("begin");

 String [] head = {"name","sex","adress","height","age","jj"};

 List<User> list = new ArrayList<User>();
 User user1 = new User("zhangsan",1,1.1f,"北京","男","AA");
 User user2 = new User("lisi",22222,3.2f,"上海","女","BB");

 list.add(user1);
 list.add(user2);

 String filePath = new CreatePdf().generatePDFs(head,list);
 System.out.println(filePath);
 System.out.println("end");
 }

8)、测试结果

9)、文件内容如下

4、其他相关链接

生成可变表头excel:http://www.cnblogs.com/0201zcr/p/4950619.html

读取excel:java使用POI批量导入excel数据的方法

java如何在pdf中生成表格,我相信通过这个简单实例演示有了大概的认识,大家可以动手去试验一下,看看会不会达到预想的效果。

(0)

相关推荐

  • Java实现操作excel表格

    最近老师布置了个任务,用Java对excel后缀名为xlsx的文件进行简单的增,删,改,查操作:虽说是个简单的程序,可作为刚接触的我来说还是有些磕磕碰碰.不过好在还是完成了,进行一个简单的总结. 首先导入了一个poi.jar 网上有很多这个资源可以下载 XSSFSheet sheet=null; XSSFWorkbook book=null; 一:查  (查找本地指定位置的excel表格,在控制台输出) public void print_excel(){ //获取excel表格的行数 int

  • Java easyui树形表格TreeGrid的实现代码

    自己搞了一下午,终于用JAVA实现了数据网格.记录一下实现的代码.(PS:此处的easyui是1.5版本,楼主只贴了核心的代码) 实现图 JSP页面 <head> //权限列表 $( document ).ready(function(){ var parentId = 0; $('#tt').treegrid({ url:'queryPrivilege.action?parentId='+parentId, idField:'id', treeField:'RecordStatus', co

  • Java创建表格实例详解 原创

    表格是最常用的数据统计形式之一,在 swing 中 由 JTable 类实现表格.接下来,我们看看怎么利用 JTable 创建表格. 在 JTable 类中除了默认的构造方法外,还提供了利用指定表格列名数组和表格数据数组创建表格的构造方法,代码如下: JTable(Object[][] rowDate,Object[] columnNames) 参数说明:         rowDate:封装表格数据的数组.         columnNames:封装表格列名的数组. 在使用表格时,通常将其添

  • Java Swing中的表格(JTable)和树(JTree)组件使用实例

    一:表格(JTable): 1.基本概念: 表格(JTable)是Swing 新增加的组件,主要是为了将数据以表格的形式显示.给显示大块数据提供了简单的机制. 2.常用构造方法: * JTable():使用系统默认的模型创建一个JTable 实例.  * JTable(int numRows,int numColumns):创建一个使用DefaultTableModel 指定行.列的空表格.  * JTable(Object[ ][ ] rowData,Object[ ][ ] columnNa

  • Java利用POI实现导入导出Excel表格示例代码

    介绍 Jakarta POI 是一套用于访问微软格式文档的Java API.Jakarta POI有很多组件组成,其中有用于操作Excel格式文件的HSSF和用于操作Word的HWPF,在各种组件中目前只有用于操作Excel的HSSF相对成熟.官方主页http://poi.apache.org/index.html,API文档http://poi.apache.org/apidocs/index.html 实现 已经在代码中加入了完整的注释. import java.io.FileInputSt

  • java在pdf中生成表格的方法

    1.目标 在pdf中生成一个可变表头的表格,并向其中填充数据.通过泛型动态的生成表头,通过反射动态获取实体类(我这里是User)的get方法动态获得数据,从而达到动态生成表格. 每天生成一个文件夹存储生成的pdf文件(文件夹的命名是年月日时间戳),如:20151110 生成的文件可能在毫秒级别,故文件的命名规则是"到毫秒的时间戳-uuid",如:20151110100245690-ece540e5-7737-4ab7-b2d6-87bc23917c8c.pdf 通过读取properti

  • Java读取PDF中的表格的方法示例

    目录 一.概述 ​二.环境配置 1. 手动导入 2. Maven仓库下载导入 三.读取PDF中的表格 一.概述 本文以Java示例展示读取PDF中的表格的方法.这里导入Spire.PDF for Javah中的jar包,并使用其提供的相关及方法来实现获取表格中的文本内容.下表中整理了本次代码使用到的主要类.方法及解释,供参考: 类型 描述 PdfDocument Class Represents a pdf document model. PdfDocument. loadFromFile (s

  • C#实现从PDF中提取表格的方法详解

    目录 程序环境 从PDF中提取表格具体步骤 完整代码 PDF是办公中比较常见的一种文件格式,在工作中应用也越来越普遍.由于PDF文件集成度和安全可靠性都较高,所以在PDF中编辑内容是一件比较复杂且困难的事.但有时因工作需要,要求我们从中提取数据或表格该怎么办呢?别担心,今天为大家介绍一种通过C#/VB.NET代码从PDF中提取表格内容的方法.下面是我整理的思路步骤及代码供大家参考. 程序环境 本次测试时,在程序中引入 Spire.PDF.dll 文件. 方法1: 将 ​ ​Free Spire.

  • Java在PDF中添加表格过程详解

    前言 本文将介绍通过Java编程在PDF文档中添加表格的方法.添加表格时,可设置表格边框.单元格对齐方式.单元格背景色.单元格合并.插入图片.设置行高.列宽.字体.字号等. 使用工具:Free Spire.PDF for Java (免费版) Jar文件获取及导入: 方法1:通过官网下载jar文件包.下载后,解压文件,将lib文件夹下的Spire.Pdf.jar文件导入Java程序. 方法2:通过maven仓库安装导入. Java 代码示例 Java代码 import com.spire.pdf

  • C# 提取PDF中的表格详情

    目录 1.简单介绍 2.环境配置 3.代码示例 1.简单介绍 本文介绍在C#程序中(附VB.NET代码)提取PDF中的表格的方法,调用Spire.PDF for .NET提供的提取表格的 类 以及 方法 等来获取表格单元格中的文本内容:代码内容中涉及到的主要类及方法归纳如下表,供参考: 类型 描述 PdfDocument Class Represents a pdf document model. PdfDocument.LoadFromFile(string filename) Method

  • Java 读取PDF中的文本和图片的方法

    本文将介绍通过Java程序来读取PDF文档中的文本和图片的方法.分别调用方法extractText()和extractImages()来读取. 使用工具:Free Spire.PDF for Java(免费版) Jar文件获取导入: 方法1:通过官网下载jar文件包.下载后,解压文件,并将lib文件夹下的Spire.Pdf.jar文件导入java程序.导入后如下图: 方法2: 可通过maven仓库安装导入. Java代码示例 import com.spire.pdf.*; import java

  • Java 在PDF中添加条形码的两种方法

    条形码,是由宽度不等的多个黑条和空白所组成,用以表达一组信息的图形标识符.通过给文档添加条形码,可以直观,快捷地访问和分享一些重要的信息.本文就将通过使用Java程序来演示如何在PDF文档中添加Codebar.Code128A和Code39条形码.除此之外,还可支持创建Code11.Code128B.Code32.Code39 Extended .Code93和Code93 Extended条形码. 使用工具:Free Spire.PDF for Java(免费版) Jar文件获取及导入: 方法

  • Java 在PDF中绘制形状的两种方法

    在我们编辑PDF文档的过程中,有时候需要在文档中添加一些如多边形.矩形.椭圆形之类的图形,而Free Spire PDF for Java 则正好可以帮助我们在Java程序中通过代码在PDF文档中绘制形状,以及设置形状边线颜色和填充色. Jar包导入 方法一:下载Free Spire.PDF for Java包并解压缩,然后将lib文件夹下的Spire.Pdf.jar包作为依赖项导入到Java应用程序中 方法二:直接通过Maven仓库安装JAR包,配置pom.xml文件的代码如下: <repos

  • Django中如何用xlwt生成表格的方法步骤

    同样是做表格,但是有些人的表格就做的很好看.融合了之前所学不同模块的知识,来讲讲Django中生成表格的特殊方法. 这里只是mark一下导出的方法,并没有做什么REST处理和异常处理. 维护统一的style样式,可以使导出的数据更加美观. def export_excel(request): # 设置HttpResponse的类型 response = HttpResponse(content_type='application/vnd.ms-excel') response['Content-

  • Java设置PDF跨页表格重复显示表头行的步骤详解

    目录 前言 1.导入Jar包 2.Java代码 总结 前言 在创建表格时,如果表格内容出现跨页显示的时候,默认情况下该表格的表头不会在下一页显示,在阅读体验上不是很好.下面分享一个方法如何在表格跨页是显示表格的表头内容,这里只需要简单使用方法 grid.setRepeatHeader(true);即可. 具体参考如下方法步骤. 1.导入Jar包 这里导入的是Free Spire.PDF for Java的jar包,Spire.PDF for Java 支持的功能非常丰富,例如 PDF 文档安全性

随机推荐