当前位置: 首页 > news >正文

翻译建设网站魔域网页游戏官网

翻译建设网站,魔域网页游戏官网,网站建设方案怎么做,做网站能不能放暴露图片最近在做一个基于Reactantd前端框架的Excel导出功能#xff0c;我主要在后端做了处理#xff0c;这个功能完成后#xff0c;便总结成一篇技术分享文章#xff0c;感兴趣的小伙伴可以参考该分享来做导出excle表格功能#xff0c;以下步骤同样适用于vue框架#xff0c;或者…最近在做一个基于Reactantd前端框架的Excel导出功能我主要在后端做了处理这个功能完成后便总结成一篇技术分享文章感兴趣的小伙伴可以参考该分享来做导出excle表格功能以下步骤同样适用于vue框架或者JSP页面的实现。 在做这类导出文件的功能其实在后端进行处理会更容易些虽然前端也可以进行处理但还是建议后端来做因为很多导出工具类基本都是很好用。 根据以下步骤可以很容易就实现导出Excel表格数据的功能。 一、开发导出图标 按钮代码 1 Button typeprimary onClick{this.excelPort} 导出/Button 二、按钮this.excelToPort的导出方法 1 excelPort () { 2 location.href/test/export.do 3 } 三、建立Excel的Entity类(以下类可以直接复制用无需做修改): 需要写一个接受前端传来表格文件到后端类——Excel Bean 1 package com.test;2 3 import lombok.Getter;4 import lombok.Setter;5 import org.apache.poi.xssf.usermodel.XSSFCellStyle;6 7 Getter8 Setter9 public class ExcelBean { 10 private String headTextName; //列头标题名 11 private String propertyName; //对应字段名 12 private Integer cols; //合并单元格数 13 private XSSFCellStyle cellStyle; 14 15 public ExcelBean(String headTextName, String propertyName, Integer cols) { 16 super(); 17 this.headTextName headTextName; 18 this.propertyName propertyName; 19 this.cols cols; 20 } 21 22 } 表格每一行的属性字段映射到数据库里的User Bean 1 package com.bqs.data.dcm.bean;2 3 import lombok.Getter;4 import lombok.Setter;5 6 Getter7 Setter8 public class User {9 private String id; 10 private String name; 11 private Integer age; 12 private String sex; 13 14 } 四、建立Excel的工具类无需修改可直接复制用 1 package com.test;2 3 import java.beans.IntrospectionException;4 import java.lang.reflect.InvocationTargetException;5 import java.text.SimpleDateFormat;6 import java.util.ArrayList;7 import java.util.Date;8 import java.util.List;9 import java.util.Map;10 11 import com.test.ExcelBean;12 import org.apache.poi.ss.util.CellRangeAddress;13 import org.apache.poi.xssf.usermodel.XSSFCell;14 import org.apache.poi.xssf.usermodel.XSSFCellStyle;15 import org.apache.poi.xssf.usermodel.XSSFFont;16 import org.apache.poi.xssf.usermodel.XSSFRow;17 import org.apache.poi.xssf.usermodel.XSSFSheet;18 import org.apache.poi.xssf.usermodel.XSSFWorkbook;19 20 /**21 * author 朱季谦22 * version 23 */24 public class ExportUtil {25 26 /**27 * 导出Excel表28 * param clazz 数据源model类型29 * param objs excel标题以及对应的model字段30 * param map 标题行数以及cell字体样式31 * param sheetName 工作簿名称32 * return33 *34 */35 public static XSSFWorkbook createExcelFile(36 Class? clazz,37 ListMapString,Object objs,38 MapInteger,ListExcelBean map,39 String sheetName) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, IntrospectionException{40 //创建新的工作簿41 XSSFWorkbook workbook new XSSFWorkbook();42 //创建工作表43 XSSFSheet sheet workbook.createSheet(sheetName);44 //设置excel的字体样式以及标题与内容的创建45 createFont(workbook);//字体样式46 createTableHeader(sheet,map);//创建标题47 createTableRows(sheet,map,objs,clazz);//创建内容48 System.out.println(workbook);49 return workbook;50 }51 private static XSSFCellStyle fontStyle;52 private static XSSFCellStyle fontStyle2;53 private static void createFont(XSSFWorkbook workbook) {54 //表头55 fontStyle workbook.createCellStyle();56 XSSFFont font1 workbook.createFont();57 font1.setBoldweight(XSSFFont.BOLDWEIGHT_BOLD);58 font1.setFontName(黑体);59 font1.setFontHeightInPoints((short) 12);//字体大小60 fontStyle.setFont(font1);61 fontStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN);//下边框62 fontStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框63 fontStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);//右边框64 fontStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框65 fontStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);//居中66 //内容67 fontStyle2 workbook.createCellStyle();68 XSSFFont font2 workbook.createFont();69 font2.setFontName(宋体);70 font2.setFontHeightInPoints((short)10);71 fontStyle2.setFont(font2);72 fontStyle2.setBorderBottom(XSSFCellStyle.BORDER_THIN);//下边框73 fontStyle2.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框74 fontStyle2.setBorderTop(XSSFCellStyle.BORDER_THIN);//右边框75 fontStyle2.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框76 fontStyle2.setAlignment(XSSFCellStyle.ALIGN_CENTER);//居中77 }78 79 80 81 /**82 * 根据ExcelMapping 生成列头(多行列头)83 * param sheet 工作簿84 * param map 每行每个单元格对应的列头信息85 */86 private static void createTableHeader(87 XSSFSheet sheet,88 MapInteger, ListExcelBean map) {89 int startIndex 0;//cell起始位置90 int endIndex 0;//cell终止位置91 for(Map.EntryInteger,ListExcelBean entry: map.entrySet()){92 XSSFRow row sheet.createRow(entry.getKey()); //创建行93 ListExcelBean excels entry.getValue();94 for(int x0;xexcels.size();x){95 //合并单元格96 if(excels.get(x).getCols()1){97 if(x0){98 endIndex excels.get(x).getCols()-1;99 //合并单元格CellRangeAddress构造参数依次表示起始行截至行起始列 截至列 100 sheet.addMergedRegion(new CellRangeAddress(0, 0, startIndex, endIndex)); 101 startIndex excels.get(x).getCols(); 102 }else{ 103 endIndex excels.get(x).getCols(); 104 sheet.addMergedRegion(new CellRangeAddress(0, 0, startIndex, endIndex)); 105 startIndex excels.get(x).getCols(); 106 } 107 XSSFCell cell row.createCell(startIndex-excels.get(x).getCols()); 108 //设置内容 109 cell.setCellValue(excels.get(x).getHeadTextName()); 110 if(excels.get(x).getCellStyle() ! null){ 111 //设置格式 112 cell.setCellStyle(excels.get(x).getCellStyle()); 113 } 114 cell.setCellStyle(fontStyle); 115 }else{ 116 XSSFCell cell row.createCell(x); 117 //设置内容 118 cell.setCellValue(excels.get(x).getHeadTextName()); 119 if(excels.get(x).getCellStyle() ! null){ 120 //设置格式 121 cell.setCellStyle(excels.get(x).getCellStyle()); 122 } 123 cell.setCellStyle(fontStyle); 124 } 125 } 126 } 127 } 128 129 130 /** 131 * 为excel表中循环添加数据 132 * param sheet 133 * param map 字段名 134 * param objs 查询的数据 135 * param clazz 无用 136 */ 137 private static void createTableRows( 138 XSSFSheet sheet, 139 MapInteger,ListExcelBean map, 140 ListMapString,Object objs, 141 Class? clazz) 142 throws IntrospectionException, IllegalAccessException, IllegalArgumentException, InvocationTargetException { 143 int rowindex map.size(); 144 int maxkey 0; 145 ListExcelBean ems new ArrayList(); 146 for(Map.EntryInteger,ListExcelBean entry : map.entrySet()){ 147 if(entry.getKey() maxkey){ 148 maxkey entry.getKey(); 149 } 150 } 151 ems map.get(maxkey); 152 ListInteger widths new ArrayListInteger(ems.size()); 153 for(MapString,Object obj : objs){ 154 XSSFRow row sheet.createRow(rowindex); 155 for(int i0;iems.size();i){ 156 ExcelBean em (ExcelBean)ems.get(i); 157 String propertyName em.getPropertyName(); 158 Object value obj.get(propertyName); 159 XSSFCell cell row.createCell(i); 160 String cellValue ; 161 if(valid.equals(propertyName)){ 162 cellValue value.equals(1)?启用:禁用; 163 }else if(valuenull){ 164 cellValue ; 165 }else if(value instanceof Date){ 166 cellValue new SimpleDateFormat(yyyy-MM-dd).format(value); 167 }else{ 168 cellValue value.toString(); 169 } 170 cell.setCellValue(cellValue); 171 cell.setCellType(XSSFCell.CELL_TYPE_STRING); 172 cell.setCellStyle(fontStyle2); 173 sheet.autoSizeColumn(i); 174 } 175 rowindex; 176 } 177 178 //设置列宽 179 for(int index0;indexwidths.size();index){ 180 Integer width widths.get(index); 181 width width2500?2500:width300; 182 width width10000?10000300:width300; 183 sheet.setColumnWidth(index, width); 184 } 185 } 186 } 五、导出Excel的controller类 1 /**2 * 导出excle表格3 */4 RequestMapping(value /export)5 public void exportTotal( HttpServletResponse response ) throws Exception{6 response.reset(); //清除buffer缓存7 //MapString,Object mapnew HashMapString,Object();8 // 指定下载的文件名9 response.setContentType(application/vnd.ms-excel;charsetUTF-8); 10 String excleName统计表格.xlsx; 11 response.setHeader(Content-Disposition,attachment;filenamenew String(excleName.getBytes(),iso-8859-1)); 12 //导出Excel对象 13 XSSFWorkbook workbook sysExportExcelInfo.exportExcel(); 14 OutputStream output; 15 try { 16 output response.getOutputStream(); 17 BufferedOutputStream bufferedOutput new BufferedOutputStream(output); 18 bufferedOutput.flush(); 19 workbook.write(bufferedOutput); 20 bufferedOutput.close(); 21 22 } catch (IOException e) { 23 e.printStackTrace(); 24 } 25 } 六、导出Excel的service类 1 public XSSFWorkbook exportExcel() throws Exception{2 //获取dao导出的list集合3 ListUser listuserService.exportUser();4 5 ListMapString,Object listMapListBeanToListMap(list);6 7 ListExcelBean excel new ArrayList();8 MapInteger,ListExcelBean map new LinkedHashMap();9 //设置标题栏 10 excel.add(new ExcelBean(序号,id,0)); 11 excel.add(new ExcelBean(名字,name,0)); 12 excel.add(new ExcelBean(年龄,age,0)); 13 14 map.put(0,excel); 15 String sheetName 统计表格; 16 //调用ExcelUtil方法 17 XSSFWorkbook xssfWorkbook ExportUtil.createExcelFile(DcmDemand.class, listMap, map, sheetName); 18 System.out.println(xssfWorkbook); 19 return xssfWorkbook; 20 } 注意整块导出Excel代码主要需要改动只是这一行代码ListUser listuserService.exportUser()这是调用dao层获取以列表list获得数据的查询。 下面三行代码里的“序号”“名字”“年龄”根据User属性来定义的它将作为表格表头呈现在导出的表格里。这里的User表映射到数据库表t_user表你需要导出User里哪些字段的数据就以这样格式excel.add(new ExcelBean(序号,id,0))加到下面代码里 1 excel.add(new ExcelBean(序号,id,0)); 2 excel.add(new ExcelBean(名字,name,0)); 3 excel.add(new ExcelBean(年龄,age,0)); 其中以上代码需要把listString转换成ListMapString,Object形式转换方法如下因为创建表格时需要这样ListMapString,Object格式类型数据 1 public static ListMapString, Object ListBeanToListMap(ListUser list) throws NoSuchMethodException,2 SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {3 ListMapString, Object listmap new ArrayListMapString, Object();4 5 for (Object ob : list) {6 7 listmap.add(beanToMap(ob));8 }9 return listmap; 10 } 按照以上代码步骤可以实现在Reactantd前端实现导出这样的Excel表格功能 若有什么不明白的可以评论留言我会尽量解答。
http://www.zqtcl.cn/news/19512/

相关文章:

  • 北京住房城乡建设网站帝国cms地方门户网站模板
  • 网站空间如何搬家网站安全建设需求分析报告
  • 宁波网站推广工具室内设计师需要学什么软件
  • 电子商务网站建设的总体设计遵义网站建设厂家
  • 九江市建设工程门户网站有那些猎头做单的网站
  • 徐州微信网站建设网站建设和维护的职责
  • 网站建设 主要学是么移动网站建设的前期规划内容
  • 网站首页index.html城乡建设部网站自助商品房
  • 休闲小零食网站开发方案网站建设拿什么框架
  • 建模外包网站相册管理网站模板
  • 微信公众号后天网站开发做网站外包公司名称大全
  • 电商网站建设费用预算搞个网站需要多少钱
  • 建立网站培训讲义什么是网站空间
  • 网站开发慕枫移动端app下载
  • 网站建设服务宗旨北流网站
  • 福建省住房城乡建设部网站成都网站建设 培训班
  • 与网络公司洽谈做网站需要注意什么网站备注查询
  • 做地方门户网站如何推广自己的网址
  • 哪些网站收录排名好如何制作电脑公司网站
  • 泗阳县建设局网站wordpress php mysql
  • 阿里云oss做网站备份网站开发硬件工程师待遇
  • 免费学设计的网站视频网站设计模板
  • php 上传到网站学校网站在建设方面的的优势
  • wordpress+ie9深圳网站seo优化公司
  • 做阿里巴巴网站店铺装修费用定西市建设厅官方网站
  • 学生作业做网站需要县城网站怎么做
  • 桓台响应式网站建设加拿大28怎么做网站代理
  • 个人域名备案网站名称安徽网站优化价格咨询
  • 网站建设运营岗位职责浙江备案需要开启网站吗
  • 做调查赚钱的网站又哪些大家都在哪些网站做宣传