您好,登錄后才能下訂單哦!
如何進行java Excel操作,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
1. 寫Excel
1.1 引入Excel 的相關文件
import java.io.FileOutputStream; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFDataFormat; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.CreationHelper;
1.2 相關實用方法:
public static void wirteExcel() throws Exception{ //創建一個工作簿 即excel文件,再在該文件中創建一個sheet HSSFWorkbook wb=new HSSFWorkbook(); HSSFSheet sheet=wb.createSheet("第一個sheet"); //在sheet中創建一行 HSSFRow row=sheet.createRow(0); //在該行寫入各種類型的數據 row.createCell(0).setCellValue(true); row.createCell(1).setCellValue("鐘林森"); row.createCell(2).setCellValue(23); //設置保留兩位小數 HSSFCell cell=row.createCell(3); cell.setCellValue(6000); HSSFCellStyle cellStyle = wb.createCellStyle(); cellStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00")); cell.setCellStyle(cellStyle); //在寫入 日期格式的 數據需要進行特殊處理(這是一種 簡單的處理方式) CreationHelper createHelper=wb.getCreationHelper(); HSSFCellStyle style=wb.createCellStyle(); style.setDataFormat(createHelper.createDataFormat().getFormat("yyyy-MM-dd")); cell=row.createCell(4); cell.setCellValue(new Date()); cell.setCellStyle(style); //最后寫回磁盤 FileOutputStream out=new FileOutputStream("E:\\excel寫數據.xls"); wb.write(out); out.close(); System.out.println("寫完了!"); } public static void writeExcelList(List<String> title,String sheetName, String filepath,List<Map<String,Object>> list){ // 創建一個工作簿 即excel 文件,再在該文件中創建一個sheet HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet(sheetName); // 表頭生成 HSSFRow row_0 = sheet.createRow(0); for(int j=0;j<title.size();j++){ row_0.createCell(j).setCellValue(title.get(j)); } // 表中每行得數據 for(int i =0;i<list.size();i++){ HSSFRow row = sheet.createRow(i+1); for(int j=0;j<title.size();j++){ Object obj = list.get(i).get(title.get(j)); row.createCell(j).setCellValue(obj.toString()); } } //最后寫回磁盤 FileOutputStream out; try { out = new FileOutputStream("E:\\excel寫數據.xls"); wb.write(out); out.close(); System.out.println("寫完了!"); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } }
1.3 測試:
public static void main(String[] args) throws Exception{ List<String> title = new ArrayList<String>(); title.add("price"); title.add("num"); title.add("amount"); List<Map<String,Object>> list = new ArrayList<Map<String,Object>>(); Map<String,Object> map = new HashMap<String,Object>(); map.put("price", "12"); map.put("num", "12"); map.put("amount", 120); list.add(map); Map<String,Object> map1 = new HashMap<String,Object>(); map1.put("price", "11"); map1.put("num", "11"); map1.put("amount", 110); list.add(map1); writeExcelList(title,"庫存成本","E:\\excel寫數據.xls",list); // wirteExcel(); }
2.API 查看:
https://poi.apache.org/apidocs/3.17/
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。