欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java在pdf中生成表格的方法

 更新時(shí)間:2015年11月27日 17:18:44   作者:WhyWin  
這篇文章主要介紹了java在pdf中生成表格的方法,需要的朋友可以參考下

1、目標(biāo)

  在pdf中生成一個(gè)可變表頭的表格,并向其中填充數(shù)據(jù)。通過(guò)泛型動(dòng)態(tài)的生成表頭,通過(guò)反射動(dòng)態(tài)獲取實(shí)體類(我這里是User)的get方法動(dòng)態(tài)獲得數(shù)據(jù),從而達(dá)到動(dòng)態(tài)生成表格。

  每天生成一個(gè)文件夾存儲(chǔ)生成的pdf文件(文件夾的命名是年月日時(shí)間戳),如:20151110

  生成的文件可能在毫秒級(jí)別,故文件的命名規(guī)則是"到毫秒的時(shí)間戳-uuid",如:20151110100245690-ece540e5-7737-4ab7-b2d6-87bc23917c8c.pdf

  通過(guò)讀取properties文件動(dòng)態(tài)獲取文件存儲(chǔ)的跟目錄。

2、所需的jar

  這里通過(guò)itex插件進(jìn)行pdf的生成,需要的jar包括以下幾個(gè)

3、編碼實(shí)現(xiàn)

1)、實(shí)體類

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存儲(chǔ)的路徑

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所在的工作路徑 
 
 //獲取到存儲(chǔ)了文件存儲(chǔ)位置的filedir.properties 文件路徑 --->java Project的文件路徑
 String realDir = dir + File.separator + "src" + File.separator +"META-INF" + File.separator + "filedir.properties";
 
     //Web project存儲(chǔ)路徑
 /*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對(duì)應(yīng)的值,
 * @param filePath properities文件路徑【包含properities文件】
 * @param key 要查找的key值
 * @return key對(duì)應(yīng)的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文件中可以對(duì)應(yīng)的存儲(chǔ)地點(diǎn)
 * @param key 查詢主鍵
 * @return key對(duì)應(yīng)的存儲(chǔ)地址
 */
 public String getFileDirFromProperties(String key)
 {
 return GetValueByKey(getFilePath(),key);
 }

}

4)、獲取當(dāng)天存在的文件路徑,不存在則生成一個(gè)新的文件夾

package com.zcr.service;

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

public class GenerateFold
{
 /**
 * 查詢當(dāng)前生成的excel需要存在在哪個(gè)路徑,如果存在則存儲(chǔ)在相應(yīng)的位置,否則生成改目錄, 每天生成一個(gè)文件夾,文件夾的命名規(guī)則為 年月日的時(shí)間戳
 * @param foldName 生成excel保存路徑
 * @return  現(xiàn)在的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
{
 /**
 * 根據(jù)文件類別生成文件的名字,文件的命名規(guī)則是:文件目錄/生成時(shí)間-uuid(全球唯一編碼).文件類別
 * @param fileDir 文件的存儲(chǔ)路徑
 * @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();// 建立一個(gè)Document對(duì)象

 private static Font headfont;// 設(shè)置字體大小
 private static Font keyfont;// 設(shè)置字體大小
 private static Font textfont;// 設(shè)置字體大小

 static
 {
 //中文格式
 BaseFont bfChinese;
 try
 {
  // 設(shè)置中文顯示
  bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H",BaseFont.NOT_EMBEDDED);
  headfont = new Font(bfChinese, 10, Font.BOLD);// 設(shè)置字體大小
  keyfont = new Font(bfChinese, 8, Font.BOLD);// 設(shè)置字體大小
  textfont = new Font(bfChinese, 8, Font.NORMAL);// 設(shè)置字體大小
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }
 
 /**
 * 文成文件
 * @param file 待生成的文件名
 */
 public CreatePdf(File file)
 {
 document.setPageSize(PageSize.A4);// 設(shè)置頁(yè)面大小
 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);// 設(shè)置頁(yè)面大小
 try
 {
  PdfWriter.getInstance(document, new FileOutputStream(file));
  document.open();
 }
 catch (Exception e)
 {
  e.printStackTrace();
 }
 }
 

 int maxWidth = 520;
 
 /**
 * 為表格添加一個(gè)內(nèi)容
 * @param value  值
 * @param font  字體
 * @param align  對(duì)齊方式
 * @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;
 }
 
 /**
 * 為表格添加一個(gè)內(nèi)容
 * @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;
 }

 /**
 * 為表格添加一個(gè)內(nèi)容
 * @param value  值
 * @param font  字體
 * @param align  對(duì)齊方式
 * @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;
 }
 
 /**
 * 為表格添加一個(gè)內(nèi)容
 * @param value  值
 * @param font  字體
 * @param align  對(duì)齊方式
 * @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;
 }

 /**
 * 創(chuàng)建一個(gè)表格對(duì)象
 * @param colNumber 表格的列數(shù)
 * @return  生成的表格對(duì)象
 */
 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();
 
 // 創(chuàng)建一個(gè)只有5列的表格
 PdfPTable table = createTable(colNum);

 // 添加備注,靠左,不顯示邊框
 table.addCell(createCell("APP信息列表:", keyfont, Element.ALIGN_LEFT, colNum,false));
 
 //設(shè)置表頭
 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
   {
   //通過(guò)反射獲得相應(yīng)的get方法,用于獲得相應(yīng)的屬性值
   method = classType.getMethod(getMethodName, new Class[]{});
   try
   {
    System.out.print(getMethodName +":" + method.invoke(t, new Class[]{}) +",");
    //添加數(shù)據(jù)
    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();
 }
 
 //關(guān)閉流
 document.close();
 }
 
 
 /**
 * 提供外界調(diào)用的接口,生成以head為表頭,list為數(shù)據(jù)的pdf
 * @param head //數(shù)據(jù)表頭
 * @param list //數(shù)據(jù)
 * @return //excel所在的路徑
 */
 public <T> String generatePDFs(String [] head,List<T> list)
 {
 final String FilePath = "pdfPath";
 String saveFilePathAndName = "";
 
 //獲得存儲(chǔ)的根目錄
 String savePath = new GetFilePlace().getFileDirFromProperties(FilePath);
 
 //獲得當(dāng)天存儲(chǔ)的路徑,不存在則生成當(dāng)天的文件夾
 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(); //生成一個(gè)pdf文件
 }
 catch (IOException e)
 {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
 new CreatePdf(file).generatePDF(head,list,head.length);
 
 return saveFilePathAndName;
 }

}

7)、測(cè)評(píng)函數(shù) 

 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)、測(cè)試結(jié)果

9)、文件內(nèi)容如下

4、其他相關(guān)鏈接

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

讀取excel:java使用POI批量導(dǎo)入excel數(shù)據(jù)的方法

java如何在pdf中生成表格,我相信通過(guò)這個(gè)簡(jiǎn)單實(shí)例演示有了大概的認(rèn)識(shí),大家可以動(dòng)手去試驗(yàn)一下,看看會(huì)不會(huì)達(dá)到預(yù)想的效果。

相關(guān)文章

  • Java DriverManager.getConnection()獲取數(shù)據(jù)庫(kù)連接

    Java DriverManager.getConnection()獲取數(shù)據(jù)庫(kù)連接

    這篇文章主要介紹了Java DriverManager.getConnection()獲取數(shù)據(jù)庫(kù)連接,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Java文檔注釋超詳細(xì)講解

    Java文檔注釋超詳細(xì)講解

    這篇文章主要給大家介紹了關(guān)于Java文檔注釋的相關(guān)資料,文檔注釋主要是用來(lái)生成java開(kāi)發(fā)文檔javadoc的,生成的開(kāi)發(fā)文檔和Java本身的API幫助文檔是一樣的,需要的朋友可以參考下
    2023-10-10
  • java 實(shí)現(xiàn)圖片圓角處理、背景透明化

    java 實(shí)現(xiàn)圖片圓角處理、背景透明化

    這篇文章主要介紹了java 實(shí)現(xiàn)圖片圓角處理、背景透明化,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java集合中的LinkedHashSet源碼解讀

    Java集合中的LinkedHashSet源碼解讀

    這篇文章主要介紹了Java集合中的LinkedHashSet源碼解讀,在LinkedHashMap中,雙向鏈表的遍歷順序通過(guò)構(gòu)造方法指定,如果沒(méi)有指定,則使用默認(rèn)順序?yàn)椴迦腠樞?即accessOrder=false,需要的朋友可以參考下
    2023-12-12
  • crawler4j抓取頁(yè)面使用jsoup解析html時(shí)的解決方法

    crawler4j抓取頁(yè)面使用jsoup解析html時(shí)的解決方法

    crawler4j對(duì)response沒(méi)有指定編碼的頁(yè)面,解析成亂碼,很讓人煩惱,下面給出解決方法,需要的朋友可以參考下
    2014-04-04
  • MybatisPlus,無(wú)XML分分鐘實(shí)現(xiàn)CRUD操作

    MybatisPlus,無(wú)XML分分鐘實(shí)現(xiàn)CRUD操作

    這篇文章主要介紹了MybatisPlus,無(wú)XML分分鐘實(shí)現(xiàn)CRUD操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • MyBatis在DAO層定義接口返回類型泛型無(wú)效的解決

    MyBatis在DAO層定義接口返回類型泛型無(wú)效的解決

    這篇文章主要介紹了MyBatis在DAO層定義接口返回類型泛型無(wú)效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java使用Apache POI庫(kù)讀取Excel表格文檔的示例

    Java使用Apache POI庫(kù)讀取Excel表格文檔的示例

    POI庫(kù)是Apache提供的用于在Windows下讀寫各類微軟Office文檔的Java庫(kù),這里我們就來(lái)看一下Java使用Apache POI庫(kù)讀取Excel表格文檔的示例:
    2016-06-06
  • jackson 實(shí)體轉(zhuǎn)json 為NULL或者為空不參加序列化(實(shí)例講解)

    jackson 實(shí)體轉(zhuǎn)json 為NULL或者為空不參加序列化(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇jackson 實(shí)體轉(zhuǎn)json 為NULL或者為空不參加序列化(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • Springboot集成Kafka進(jìn)行批量消費(fèi)及踩坑點(diǎn)

    Springboot集成Kafka進(jìn)行批量消費(fèi)及踩坑點(diǎn)

    本文主要介紹了Springboot集成Kafka進(jìn)行批量消費(fèi)及踩坑點(diǎn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12

最新評(píng)論