日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

java實現(xiàn)Excel的導入導出

瀏覽:213日期:2022-05-29 13:00:55

本文實例為大家分享了java實現(xiàn)Excel導入導出的具體代碼,供大家參考,具體內(nèi)容如下

一.Excel讀寫技術(shù)

java實現(xiàn)Excel的導入導出

區(qū)別:

java實現(xiàn)Excel的導入導出

二.jxl讀寫基礎(chǔ)代碼

1.從數(shù)據(jù)庫將數(shù)據(jù)導出到excel表格

public class JxlExcel {public static void main(String[] args) { //創(chuàng)建Excel文件 String[] title= {'姓名','課程名','分數(shù)'}; File file=new File('f:/sheet1.xls'); try { file.createNewFile(); //創(chuàng)建工作簿 WritableWorkbook workbook=Workbook.createWorkbook(file); //創(chuàng)建Sheet WritableSheet sheet=workbook.createSheet('表格一', 20); //第一行設(shè)置列名 Label label=null; for (int i = 0; i < title.length; i++) { label=new Label(i, 0, title[i]);//第一個參數(shù)為列,第二個為行 sheet.addCell(label); } Data data=new Data(); ResultSet rs=data.getString(); while(rs.next()) { System.out.println(rs.getString(1)); label=new Label(0,rs.getRow(),rs.getString(1)); sheet.addCell(label); label=new Label(1,rs.getRow(),rs.getString(2)); sheet.addCell(label); label=new Label(2,rs.getRow(),rs.getString(3)); sheet.addCell(label); } workbook.write(); workbook.close(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }} }

2.從Excel表格中讀取數(shù)據(jù)

public class JxlRead {public static void main(String[] args) { //創(chuàng)建workbook try { Workbook workbook=Workbook.getWorkbook(new File('f:/sheet1.xls')); //獲取第一個表格 Sheet sheet=workbook.getSheet(0); //獲取數(shù)據(jù) for (int i = 0; i < sheet.getRows(); i++) { for (int j = 0; j < sheet.getColumns(); j++) { Cell cell=sheet.getCell(j, i); System.out.print(cell.getContents()+' '); } System.out.println(); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } }}

三.Poi讀寫基礎(chǔ)代碼

//所需jar包:commons-io-2.2.jar;poi-3.11-20141221.jar//通過poi進行excel導入數(shù)據(jù)public class PoiExcel {public static void main(String[] args) throws SQLException { String title[]= {'名字','課程','分數(shù)'}; //1.創(chuàng)建Excel工作簿 HSSFWorkbook workbook=new HSSFWorkbook(); //2.創(chuàng)建一個工作表 HSSFSheet sheet=workbook.createSheet('sheet2'); //3.創(chuàng)建第一行 HSSFRow row=sheet.createRow(0); HSSFCell cell=null; //4.插入第一行數(shù)據(jù) for (int i = 0; i < title.length; i++) { cell=row.createCell(i); cell.setCellValue(title[i]); } //5.追加數(shù)據(jù) Data data=new Data(); ResultSet rs=data.getString(); while(rs.next()) { HSSFRow row2=sheet.createRow(rs.getRow()); HSSFCell cell2=row2.createCell(0); cell2.setCellValue(rs.getString(1)); cell2=row2.createCell(1); cell2.setCellValue(rs.getString(2)); cell2=row2.createCell(2); cell2.setCellValue(rs.getString(3)); } //創(chuàng)建一個文件,將Excel內(nèi)容存盤 File file=new File('e:/sheet2.xls'); try { file.createNewFile(); FileOutputStream stream=FileUtils.openOutputStream(file); workbook.write(stream); stream.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }}

//將Excel表中內(nèi)容讀取public class PoiRead {public static void main(String[] args) { //需要解析的Excel文件 File file=new File('e:/sheet2.xls'); try { //獲取工作簿 FileInputStream fs=FileUtils.openInputStream(file); HSSFWorkbook workbook=new HSSFWorkbook(fs); //獲取第一個工作表 HSSFSheet hs=workbook.getSheetAt(0); //獲取Sheet的第一個行號和最后一個行號 int last=hs.getLastRowNum(); int first=hs.getFirstRowNum(); //遍歷獲取單元格里的信息 for (int i = first; i <last; i++) { HSSFRow row=hs.getRow(i); int firstCellNum=row.getFirstCellNum();//獲取所在行的第一個行號 int lastCellNum=row.getLastCellNum();//獲取所在行的最后一個行號 for (int j = firstCellNum; j <lastCellNum; j++) { HSSFCell cell=row.getCell(j); String value=cell.getStringCellValue(); System.out.print(value+' '); } System.out.println(); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }}}

如果Excel版本過高則需要改寫用XSSF

public class PoiExpExcel2 { /** * POI生成Excel文件 * @author David * @param args */ public static void main(String[] args) { String[] title = {'id','name','sex'}; //創(chuàng)建Excel工作簿 XSSFWorkbook workbook = new XSSFWorkbook(); //創(chuàng)建一個工作表sheet Sheet sheet = workbook.createSheet(); //創(chuàng)建第一行 Row row = sheet.createRow(0); Cell cell = null; //插入第一行數(shù)據(jù) id,name,sex for (int i = 0; i < title.length; i++) { cell = row.createCell(i); cell.setCellValue(title[i]); } //追加數(shù)據(jù) for (int i = 1; i <= 10; i++) { Row nextrow = sheet.createRow(i); Cell cell2 = nextrow.createCell(0); cell2.setCellValue('a' + i); cell2 = nextrow.createCell(1); cell2.setCellValue('user' + i); cell2 = nextrow.createCell(2); cell2.setCellValue('男'); } //創(chuàng)建一個文件 File file = new File('e:/poi_test.xlsx'); try { file.createNewFile(); //將Excel內(nèi)容存盤 FileOutputStream stream = FileUtils.openOutputStream(file); workbook.write(stream); stream.close(); } catch (IOException e) { e.printStackTrace(); } } }

四.定制導入模板

1.首先準備好模板的.xml文件,然后導入所需的jar包

例子:student.xml文件

<?xml version='1.0' encoding='UTF-8'?><excel code='student' name='學生信息導入'> <colgroup> <col index='A' width=’17em’></col> <col index='B' width=’17em’></col> <col index='C' width=’17em’></col> <col index='D' width=’17em’></col> <col index='E' width=’17em’></col> <col index='F' width=’17em’></col> </colgroup> <title> <tr height='16px'> <td rowspan='1' colspan='6' value='學生信息導入' /> </tr> </title> <thead> <tr height='16px'> <th value='編號' /> <th value='姓名' /> <th value='年齡' /> <th value='性別' /> <th value='出生日期' /> <th value=' 愛好' /> </tr> </thead> <tbody> <tr firstrow='2' firstcol='0' repeat='5'> <td type='string' isnullable='false' maxlength='30' /><!--用戶編號 --> <td type='string' isnullable='false' maxlength='50' /><!--姓名 --> <td type='numeric' format='##0' isnullable='false' /><!--年齡 --> <td type='enum' format='男,女' isnullable='true' /><!--性別 --> <td type='date' isnullable='false' maxlength='30' /><!--出生日期 --> <td type='enum' format='足球,籃球,乒乓球' isnullable='true' /><!--愛好 --> </tr> </tbody></excel>

所需jar包:commons-lang3-3.1.jarjdom.jarpoi-3.11-20141221.jarcommons-io-2.2.jar

java代碼:

//準備工作:導入相關(guān)jar包commons-lang3-3.1.jar,jdom.jar,poi-3.11-20141221.jarpublic class CreateTemp {public static void main(String[] args) { //獲取解析Xml路徑 String path=System.getProperty('user.dir')+'/student.xml'; File file=new File(path); SAXBuilder builder=new SAXBuilder(); //解析xml文件 try { Document document=builder.build(file); //創(chuàng)建Excel HSSFWorkbook workbook=new HSSFWorkbook(); //創(chuàng)建表格 HSSFSheet sheet=workbook.createSheet('sheet0'); //獲取Xml文件的根節(jié)點 Element root=document.getRootElement(); //獲取模板名稱 String tempName=root.getAttributeValue('name'); //設(shè)置列寬 Element colgroup=root.getChild('colgroup'); setColumnWidth(sheet,colgroup); //設(shè)置標題 int rownum = 0; int column = 0; Element title=root.getChild('title'); List<Element> trs=title.getChildren('tr'); for (int i = 0; i <trs.size(); i++) { Element tr=trs.get(i); List<Element> tds=tr.getChildren('td'); HSSFRow row=sheet.createRow(rownum); HSSFCellStyle cellStyle=workbook.createCellStyle();//創(chuàng)建單元格格式 cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//標題居中 for (int j = 0; j < tds.size(); j++) { Element td=tds.get(j); HSSFCell cell=row.createCell(j); Attribute rowspan=td.getAttribute('rowspan'); Attribute colspan=td.getAttribute('colspan'); Attribute value=td.getAttribute('value'); if (value!=null) { String content=value.getValue(); cell.setCellValue(content); int rspan=rowspan.getIntValue()-1; int cspan=colspan.getIntValue()-1; //設(shè)置字體 HSSFFont font=workbook.createFont(); font.setFontName('仿宋_GB2312'); font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//字體加粗// font.setFontHeight((short)12); font.setFontHeightInPoints((short)12); cellStyle.setFont(font); cell.setCellStyle(cellStyle); //合并單元格居中 sheet.addMergedRegion(new CellRangeAddress(rspan, rspan, 0, cspan)); } } rownum++; } //設(shè)置表頭 Element thead=root.getChild('thead'); trs=thead.getChildren('tr'); for (int i = 0; i < trs.size(); i++) { Element tr=trs.get(i); HSSFRow row=sheet.createRow(rownum); List<Element> ths=tr.getChildren('th'); for (int j = 0; j <ths.size(); j++) { Element th=ths.get(j); HSSFCell cell=row.createCell(j); Attribute value=th.getAttribute('value'); if (value!=null) { String content=value.getValue(); cell.setCellValue(content); } } rownum++; } //設(shè)置數(shù)據(jù)區(qū)域樣式 Element tbody = root.getChild('tbody'); Element tr=tbody.getChild('tr'); int repeat=tr.getAttribute('repeat').getIntValue(); List<Element> tds=tr.getChildren('td'); for (int i = 0; i < repeat; i++) { HSSFRow row=sheet.createRow(rownum); for (int j = 0; j < tds.size(); j++) { Element td=tds.get(j); HSSFCell cell=row.createCell(j); setType(workbook,cell,td); } } rownum++; //生成Excel導入模板 File tempFile=new File('e:/'+tempName+'.xls'); tempFile.delete(); tempFile.createNewFile(); FileOutputStream fos=FileUtils.openOutputStream(tempFile); workbook.write(fos); fos.close(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }} private static void setType(HSSFWorkbook workbook, HSSFCell cell, Element td) { Attribute typeAttr = td.getAttribute('type'); String type = typeAttr.getValue(); HSSFDataFormat format = workbook.createDataFormat(); HSSFCellStyle cellStyle = workbook.createCellStyle(); if('NUMERIC'.equalsIgnoreCase(type)){ cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC); Attribute formatAttr = td.getAttribute('format'); String formatValue = formatAttr.getValue(); formatValue = StringUtils.isNotBlank(formatValue)? formatValue : '#,##0.00'; cellStyle.setDataFormat(format.getFormat(formatValue)); }else if('STRING'.equalsIgnoreCase(type)){ cell.setCellValue(''); cell.setCellType(HSSFCell.CELL_TYPE_STRING); cellStyle.setDataFormat(format.getFormat('@')); }else if('DATE'.equalsIgnoreCase(type)){ cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC); cellStyle.setDataFormat(format.getFormat('yyyy-m-d')); }else if('ENUM'.equalsIgnoreCase(type)){ CellRangeAddressList regions = new CellRangeAddressList(cell.getRowIndex(), cell.getRowIndex(), cell.getColumnIndex(), cell.getColumnIndex()); Attribute enumAttr = td.getAttribute('format'); String enumValue = enumAttr.getValue(); //加載下拉列表內(nèi)容 DVConstraint constraint = DVConstraint.createExplicitListConstraint(enumValue.split(',')); //數(shù)據(jù)有效性對象 HSSFDataValidation dataValidation = new HSSFDataValidation(regions, constraint); workbook.getSheetAt(0).addValidationData(dataValidation); } cell.setCellStyle(cellStyle); } private static void setColumnWidth(HSSFSheet sheet, Element colgroup) { List<Element> cols=colgroup.getChildren('col');//獲取col的節(jié)點 for (int i = 0; i < cols.size(); i++) { Element col=cols.get(i); Attribute width=col.getAttribute('width');//獲取每列中的width屬性 String unit = width.getValue().replaceAll('[0-9,.]', '');//單位 String value = width.getValue().replaceAll(unit, '');//數(shù)值 int v=0; if(StringUtils.isBlank(unit) || 'px'.endsWith(unit)){ v = Math.round(Float.parseFloat(value) * 37F); }else if ('em'.endsWith(unit)){ v = Math.round(Float.parseFloat(value) * 267.5F); }//對單位進行判斷 sheet.setColumnWidth(i, v); } }}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: excel
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产不卡人人| 在线国产日韩| 久久国产亚洲| 欧美xxxx性| 日韩欧美2区| 久久精品青草| 国产精品多人| 亚洲精品在线a| 给我免费播放日韩视频| 日本国产亚洲| 欧美女激情福利| 国产一在线精品一区在线观看| 国产精品毛片在线看| 蜜乳av另类精品一区二区| 国产精区一区二区| 欧美日韩国产v| 久久九九国产| 亚洲va在线| 国产亚洲亚洲| 蜜桃视频一区二区三区在线观看| 水野朝阳av一区二区三区| 日本视频中文字幕一区二区三区| 日本一区二区三区中文字幕| 日本成人精品| 亚洲欧美日韩视频二区| 午夜久久av| 国产一区二区精品福利地址| 国产精品毛片视频| 中日韩男男gay无套| 久久亚洲美女| 91精品美女| 精品国产鲁一鲁****| 在线成人直播| 欧美日本久久| 加勒比视频一区| 日本欧美不卡| 国产亚洲在线| 国产激情一区| 精品视频一二| 亚洲一区二区三区四区五区午夜 | 国产精品黄网站| 美女网站一区| 国产精选一区| 日韩激情av在线| 日产午夜精品一线二线三线| 999久久久国产精品| 日本午夜精品视频在线观看| 国内精品福利| 国产亚洲久久| 国产精品色在线网站| 日韩国产一二三区| 日韩一级欧洲| 天堂中文av在线资源库| 久久国产欧美日韩精品| 久久这里只有| 日韩欧美美女在线观看| 日韩国产在线| 欧美日韩亚洲一区二区三区在线| 日韩精品三级| 另类国产ts人妖高潮视频| 久久国产中文字幕| 免费一级欧美片在线观看网站 | 欧美1级日本1级| 91大神在线观看线路一区| 亚洲制服少妇| 国产精品成久久久久| 亚洲一区日韩| 尤物tv在线精品| 久久久91麻豆精品国产一区| 五月天av在线| 欧美日韩调教| 蜜臀精品一区二区三区在线观看 | 国产精品激情| 国产精品xvideos88| 国产视频一区二| 亚洲精品九九| 国产精品一区二区精品视频观看| 亚洲四虎影院| 久久中文亚洲字幕| 99精品综合| 亚洲日产国产精品| 乱人伦精品视频在线观看| 亚洲深夜影院| 欧洲一级精品| 国产高潮在线| 国产在线不卡一区二区三区| 国产精品视频一区二区三区 | 欧美成a人免费观看久久| 国产一区二区三区国产精品| 嫩草伊人久久精品少妇av杨幂| 麻豆极品一区二区三区| 国产欧美自拍| 日韩av在线播放中文字幕| 日韩在线观看| 美女久久一区| 精品午夜久久| 在线天堂中文资源最新版| 日韩精品专区| 午夜一级在线看亚洲| 亚洲免费影视| 石原莉奈在线亚洲三区| 国产欧美亚洲一区| 欧美成人精品午夜一区二区| 国产日韩免费| 久久久精品网| 亚久久调教视频| 久久精品国产久精国产爱| 成人午夜在线| 综合国产精品| 国产精品网站在线看| 午夜精品成人av| 国产亚洲欧美日韩在线观看一区二区 | 国产精品毛片一区二区在线看| 成人精品亚洲| 麻豆亚洲精品| 国产欧美一区二区三区米奇| 欧美成人久久| 日本不卡高清| 精品国产一区二区三区性色av| 首页国产欧美久久| 亚洲欧洲午夜| 日韩精品视频一区二区三区| 欧美日韩精品一本二本三本| 男女男精品网站| 在线亚洲观看| 日本va欧美va瓶| 国产视频一区欧美| 欧美日韩精品在线一区| 中文字幕一区二区av| 另类国产ts人妖高潮视频| 亚洲一区国产一区| 国产剧情在线观看一区| 国产国产精品| 国产精品香蕉| 国产伦理久久久久久妇女| 久久女人天堂| 日本欧美一区二区在线观看| 国产一区91| 四虎8848精品成人免费网站| 久久国产亚洲| 久久精品福利| 国内揄拍国内精品久久| 亚洲三级毛片| 亚洲一区网站| yellow在线观看网址| 视频一区二区国产| 日韩在线不卡| 成人一区而且| re久久精品视频| 亚洲资源av| 亚洲aa在线| 日本不卡不码高清免费观看| 亚洲二区在线| 久久麻豆精品| 日本欧洲一区二区| 欧美日本不卡| 久久中文视频| 亚洲欧洲一区| 日本精品在线中文字幕| 日韩伦理在线一区| 日韩精品影视| 亚洲精品日韩久久| 国产视频一区二| 麻豆视频一区二区| 亚洲午夜av| 亚洲视频国产| 综合激情网...| 日韩福利在线观看| 91福利精品在线观看| 亚洲精一区二区三区| 日韩高清三区| 一本一道久久a久久精品蜜桃| 欧美激情日韩| 日韩欧美国产精品综合嫩v| 99视频精品视频高清免费| 制服诱惑一区二区| 国产精品啊v在线| 老司机精品视频在线播放| 九九久久婷婷| 女主播福利一区| 亚洲欧美日本国产专区一区| 欧美/亚洲一区| 蜜桃国内精品久久久久软件9| 国产精品日韩欧美一区| 日韩欧美2区| 国产在线|日韩| 尤物tv在线精品| 国产综合亚洲精品一区二| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲香蕉久久| 丝袜美腿亚洲一区| 成人综合一区| 综合激情网站| 久久爱www.| 狠狠干成人综合网| 成人三级高清视频在线看| 日韩一区二区久久| 在线日韩中文| 国产日韩一区二区三区在线播放| 亚洲成人va|