国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > Apache > 正文

Java通過apache poi生成excel實例代碼

2024-08-27 18:25:22
字體:
來源:轉載
供稿:網友

首先,jar

maven 添加依賴

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml --><dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.15</version></dependency>

開始以為是poi,然后就直接加poi的依賴,誰知道并沒有所需要的類。查了查才發現是poi-ooxml

要用到的類

XSSFWorkbook , 代表一個excel文檔 XSSFSheet , 代表文檔中的一個sheet XSSFRow , 代表sheet中的一行 XSSFCell , 代表row中的每一項的值

最最基本的使用

//創建excel文檔XSSFWorkbook workbook = new XSSFWorkbook();//創建sheetXSSFSheet sheet = workbook.createSheet("sheetName");int rownum=0;//創建首行XSSFRow firstrow = sheet.createRow(rownum++);int cellnum = 0;//把保存在titles中的各個列名,分別在row中創建cellfor(String key : titles){ XSSFCell cell = firstrow.createCell(cellnum++); cell.setCellValue(key);}//下面可以繼續創建行//把excel寫到要寫的outputStream中workbook.write(output);//最后關閉workbook.close();

小例子一枚

利用反射,把bean類中各屬性(用getXxx取出),寫入到excel中

ExcelUtil.java

package me.paul.excelDemo;import java.io.IOException;import java.io.OutputStream;import java.lang.reflect.InvocationTargetException;import java.lang.reflect.Method;import java.util.LinkedHashMap;import java.util.List;import java.util.Map;import java.util.regex.Matcher;import java.util.regex.Pattern;import org.apache.poi.xssf.usermodel.XSSFCell;import org.apache.poi.xssf.usermodel.XSSFRow;import org.apache.poi.xssf.usermodel.XSSFSheet;import org.apache.poi.xssf.usermodel.XSSFWorkbook;public class ExcelUtil {  public <T> void getExcel(List<T> list,Class<T> c,OutputStream output) throws IOException, IllegalAccessException, IllegalArgumentException, InvocationTargetException{ Map<String,Method> methodMap = new LinkedHashMap<>();  Method[] methods = c.getDeclaredMethods(); for(int i=0;i<methods.length;i++){  Method method = methods[i];  String name = method.getName();  Pattern pattern = Pattern.compile("get(.*)");  Matcher matcher = null;  if((matcher = pattern.matcher(name)).matches()){  name = matcher.group(1);  char ch = name.charAt(0);  char newch = (char) (ch + 32);   name = name.replace(ch,newch);  methodMap.put(name, method);  } }  XSSFWorkbook workbook = new XSSFWorkbook(); XSSFSheet sheet = workbook.createSheet(c.getCanonicalName()); int rownum=0; XSSFRow firstrow = sheet.createRow(rownum++); int cellnum = 0; for(String key : methodMap.keySet()){  XSSFCell cell = firstrow.createCell(cellnum++);  cell.setCellValue(key); }  for(T t : list){  XSSFRow row = sheet.createRow(rownum++);  cellnum = 0;  for(String key:methodMap.keySet()){  Method method = methodMap.get(key);                //設置可訪問,之前不知道這方法,所以關于反射那篇文章有錯誤,見諒見諒                method.setAccessible(true);  Object obj = method.invoke(t);  XSSFCell cell = row.createCell(cellnum++);  cell.setCellValue(obj== null ? "":obj.toString());  }   } workbook.write(output); workbook.close(); } }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 伊春市| 琼结县| 册亨县| 汉川市| 镇赉县| 简阳市| 泾源县| 达日县| 昔阳县| 抚远县| 宾川县| 大方县| 丰县| 晋城| 闻喜县| 余庆县| 南乐县| 常山县| 任丘市| 尼玛县| 铜陵市| 图木舒克市| 驻马店市| 阳高县| 兰坪| 阿尔山市| 广州市| 云梦县| 济阳县| 太康县| 荥阳市| 巢湖市| 闵行区| 锡林浩特市| 陈巴尔虎旗| 贡觉县| 江口县| 祁阳县| 南召县| 炉霍县| 吐鲁番市|