新手学习中,记录一下excel导出功能实现的整个流程。使用框架ssm。

control层 importExcel+parseDataItem:

[java] view plaincopy
  1. @RequestMapping("importExcel.do")
  2. public String importExcel(@RequestParam MultipartFile uploadfile,
  3. HttpServletRequest request, HttpServletResponse response) {
  4. String fileName = uploadfile.getOriginalFilename();
  5. if (StringUtils.isEmpty(fileName)) {
  6. System.out.println("未上传文件名为空");
  7. }
  8. String tempPath = request.getSession().getServletContext().getRealPath("/")
  9. + "upload";
  10. File dir = new File(tempPath);
  11. if (!tempPath.endsWith(File.separator)) {
  12. tempPath = tempPath + File.separator;
  13. }
  14. if (!dir.exists()) {
  15. dir.mkdirs();
  16. }
  17. System.out.println(tempPath);
  18. //制作路径
  19. String newFile = tempPath + fileName;
  20. File file = new File(newFile);
  21. try {
  22. FileCopyUtils.copy(uploadfile.getBytes(), file);
  23. //导入excel中的内容
  24. this.<span style="color:#ff0000;">parseDataItem</span>(newFile);
  25. System.out.println("成功导入");
  26. } catch (IOException e) {
  27. e.printStackTrace();
  28. } finally {
  29. try {
  30. FileUtils.forceDelete(file);
  31. } catch (IOException e) {
  32. e.printStackTrace();
  33. return "uploadfail";
  34. }
  35. }
  36. return "uploadsuccess";
  37. }
  38. public final boolean <span style="color:#ff0000;">parseDataItem</span>(String file){
  39. return ysdwAnimalService.<span style="color:#ff0000;">importExcel</span>(file);
  40. }

ysdwAnimalService层 import 调用底层通用方法readExcel:

[java] view plaincopy
  1. @Transactional
  2. public boolean importExcel(String file) {
  3. final int rowStart = 2;
  4. final int cellStrart = 0;
  5. List<YsdwAnimal> list = new LinkedList<YsdwAnimal>();
  6. YsdwAnimal ysdwAnimal = null;
  7. try {
  8. List<Object> dataList = ReadExcleUtils.<span style="color:#ff0000;">readExcel</span>(file, new YsdwAnimalExcel(), rowStart, cellStrart);
  9. for (Object object : dataList) {
  10. YsdwAnimalExcel excel = (YsdwAnimalExcel) object;
  11. ysdwAnimal = new YsdwAnimal();
  12. String uuid = CommonUtils.getUuid();
  13. ysdwAnimal.setId(uuid);
  14. ysdwAnimal.setAnimalname(excel.getAnimalname());
  15. ysdwAnimal.setAnimalnumber(excel.getAnimalnumber());
  16. ysdwAnimal.setAnimaltypes(excel.getAnimaltypes());
  17. ysdwAnimal.setVegetationtypes(excel.getVegetationtypes());
  18. ysdwAnimal.setJingdu(excel.getJingdu());
  19. ysdwAnimal.setWeidu(excel.getWeidu());
  20. ysdwAnimal.setPodu(excel.getPodu());
  21. ysdwAnimal.setPowei(excel.getPowei());
  22. ysdwAnimal.setPoxiang(excel.getPoxiang());
  23. ysdwAnimal.setZuobiao(excel.getZuobiao());
  24. ysdwAnimal.setHaiba(excel.getHaiba());
  25. ysdwAnimal.setTianqi(excel.getTianqi());
  26. ysdwAnimal.setJilusj(excel.getJilusj());
  27. ysdwAnimal.setQita(excel.getQita());
  28. ysdwAnimal.setDid(excel.getDid());
  29. ysdwAnimal.setBaohdj(excel.getBaohdj());
  30. list.add(ysdwAnimal);
  31. }
  32. //存库
  33. for (YsdwAnimal YsdwAnimal : list) {
  34. YsdwAnimalMapper.saveOrUpdate(YsdwAnimal);
  35. System.out.println("存库");
  36. }
  37. } catch (IOException e) {
  38. e.printStackTrace();
  39. return false;
  40. }
  41. return true;
  42. }

底层通用方法readExcel

[java] view plaincopy
  1. /**
  2. * 读取EXCLE2007的方法
  3. * @param filePath 文件名
  4. * @param obj 对象名
  5. * @param rowStart 起点行(从0开始)
  6. * @param cellStrart 起点列(从0开始)
  7. * @return 对象集合
  8. * @throws IOException
  9. */
  10. @SuppressWarnings("rawtypes")
  11. public static List<Object> readExcel(final String filePath, final Object obj, final int rowStart, final int cellStrart) throws IOException {
  12. List<Object> aList = null;
  13. final String extension = filePath.substring(filePath.lastIndexOf(".")+1, filePath.length());//截取文件扩展名
  14. final Class c = obj.getClass();//获得类对象
  15. <span style="color:#cc0000;">final Field[] filds = c.getDeclaredFields();//获得该类中所有的属性</span>
  16. final File excelFile = new File(filePath);
  17. final InputStream is = new FileInputStream(excelFile);// 获取文件输入流
  18. if ("xlsx".equals(extension)) {//解析2007
  19. aList = ReadExcleUtils.<span style="color:#ff0000;">analyExcle2007</span>(c, is, filds, rowStart, cellStrart);
  20. } else if ("xls".equals(extension)) {
  21. aList = ReadExcleUtils.<span style="color:#ff0000;">analyExcle2003</span>(c, is, filds, rowStart, cellStrart);
  22. } else {
  23. System.out.println("上传文件不正确");
  24. }
  25. return aList;
  26. }
  27. @SuppressWarnings("rawtypes")
  28. private static List<Object> analyExcle2007(final Class c, final InputStream is, final Field[] filds, final int rowStart, final int cellStrart) throws IOException {
  29. Object objs = null;
  30. Map<String,Object> mapAtt = null;
  31. final List<Object> aList = new ArrayList<Object>();
  32. final XSSFWorkbook workbook2007 = new XSSFWorkbook(is);// 创建Excel2007文件对象
  33. final XSSFSheet sheet = workbook2007.getSheetAt(0);// 取出第一个工作表,索引是0
  34. final XSSFFormulaEvaluator evaluator=new XSSFFormulaEvaluator(workbook2007);
  35. for (int i = rowStart; i <= sheet.getLastRowNum(); i++) {
  36. String cellStr = null;// 单元格,最终按字符串处理
  37. final XSSFRow row = sheet.getRow(i);// 获取行对象
  38. if (row == null) {// 如果为空,不处理
  39. continue;
  40. }else {
  41. mapAtt = new HashMap<String,Object>();
  42. for (int j = 0; j < filds.length; j++) {
  43. final XSSFCell cell = row.getCell(j+cellStrart);
  44. //判断单元格的数据类型
  45. if (cell != null) {
  46. //对时间的特殊处理
  47. int dataFormat = cell.getCellStyle().getDataFormat();
  48. if (dataFormat == 14 || dataFormat == 176 || dataFormat == 178 || dataFormat == 180 || dataFormat == 181 || dataFormat == 182) {
  49. cellStr = ReadExcleUtils.getDateValue2007(cell);
  50. } else{
  51. switch (cell.getCellType()) {
  52. case HSSFCell.CELL_TYPE_NUMERIC://数值
  53. BigDecimal db = new BigDecimal(cell.getNumericCellValue());
  54. if (db.toString().indexOf(".") != -1) {
  55. java.text.DecimalFormat dfomat = new java.text.DecimalFormat("0.000000");
  56. cellStr = dfomat.format(db);
  57. }else {
  58. cellStr = db.toPlainString();
  59. }
  60. //                              cellStr = db.toPlainString();
  61. //                              cellStr = String.valueOf(cell.getNumericCellValue());
  62. break;
  63. case HSSFCell.CELL_TYPE_STRING://字符串
  64. cellStr = cell.getStringCellValue();
  65. break;
  66. case HSSFCell.CELL_TYPE_BOOLEAN://布尔
  67. cellStr = String.valueOf(cell.getBooleanCellValue());
  68. break;
  69. case HSSFCell.CELL_TYPE_FORMULA://公式
  70. cellStr = String.valueOf(evaluator.evaluate(cell).getNumberValue());
  71. break;
  72. case HSSFCell.CELL_TYPE_BLANK://空值
  73. cellStr =  "";
  74. break;
  75. default:
  76. cellStr = cell.getStringCellValue();
  77. break;
  78. }
  79. }
  80. } else {
  81. cellStr = null;
  82. }
  83. //讲单元格中的数据放入集合中
  84. mapAtt.put(filds[j].getName(), cellStr);
  85. }
  86. }
  87. try {
  88. objs = c.newInstance();
  89. ReadExcleUtils.invokeMethod(c, objs, mapAtt);
  90. aList.add(objs);
  91. } catch (InstantiationException e) {
  92. // TODO Auto-generated catch block
  93. e.printStackTrace();
  94. } catch (IllegalAccessException e) {
  95. // TODO Auto-generated catch block
  96. e.printStackTrace();
  97. }
  98. }
  99. return aList;
  100. }
  101. @SuppressWarnings("rawtypes")
  102. private static List<Object> analyExcle2003(final Class c, final InputStream is, final Field[] filds, final int rowStart, final int cellStrart) throws IOException {
  103. Object objs = null;
  104. Map<String,Object> mapAtt = null;
  105. final List<Object> aList = new ArrayList<Object>();
  106. final HSSFWorkbook workbook2003 = new HSSFWorkbook(is);// 创建Excel2003文件对象
  107. final HSSFSheet sheet = workbook2003.getSheetAt(0);// 取出第一个工作表,索引是0
  108. final HSSFFormulaEvaluator evaluator = new HSSFFormulaEvaluator(workbook2003);
  109. for (int i = rowStart; i <= sheet.getLastRowNum(); i++) {
  110. final HSSFRow row = sheet.getRow(i);// 获取行对象
  111. if (row == null) {// 如果为空,不处理
  112. continue;
  113. }else {
  114. mapAtt = new HashMap<String,Object>();
  115. for (int j = 0; j < filds.length; j++) {
  116. String cellStr = null;// 单元格,最终按字符串处理
  117. final HSSFCell cell = row.getCell(j+cellStrart);
  118. //判断单元格的数据类型
  119. if (cell != null) {
  120. //对时间的特殊处理
  121. int dataFormat = cell.getCellStyle().getDataFormat();
  122. //                      if (dataFormat == 14 || dataFormat == 178 || dataFormat == 180 || dataFormat == 181 || dataFormat == 182) {
  123. if (dataFormat == 14 || dataFormat == 31 || dataFormat == 57 || dataFormat == 58) {
  124. cellStr = ReadExcleUtils.getDateValue2003(cell);
  125. } else{
  126. switch (cell.getCellType()) {
  127. case HSSFCell.CELL_TYPE_NUMERIC://数值
  128. BigDecimal db = new BigDecimal(cell.getNumericCellValue());
  129. if (db.toString().indexOf(".") != -1) {
  130. java.text.DecimalFormat dfomat = new java.text.DecimalFormat("0.000000");
  131. cellStr = dfomat.format(db);
  132. }else {
  133. cellStr = db.toPlainString();
  134. }
  135. break;
  136. case HSSFCell.CELL_TYPE_STRING://字符串
  137. cellStr = cell.getStringCellValue();
  138. break;
  139. case HSSFCell.CELL_TYPE_BOOLEAN://布尔
  140. cellStr = String.valueOf(cell.getBooleanCellValue());
  141. break;
  142. case HSSFCell.CELL_TYPE_FORMULA://公式
  143. cellStr = String.valueOf(evaluator.evaluate(cell).getNumberValue());
  144. break;
  145. case HSSFCell.CELL_TYPE_BLANK://空值
  146. cellStr =  "";
  147. break;
  148. default:
  149. cellStr = cell.getStringCellValue();
  150. break;
  151. }
  152. }
  153. } else {
  154. cellStr = null;
  155. }
  156. //讲单元格中的数据放入集合中
  157. mapAtt.put(filds[j].getName(), cellStr);
  158. }
  159. }
  160. try {
  161. objs = c.newInstance();
  162. ReadExcleUtils.invokeMethod(c, objs, mapAtt);
  163. aList.add(objs);
  164. } catch (InstantiationException e) {
  165. // TODO Auto-generated catch block
  166. e.printStackTrace();
  167. } catch (IllegalAccessException e) {
  168. // TODO Auto-generated catch block
  169. e.printStackTrace();
  170. }
  171. }
  172. return aList;
  173. }

注意!!在底层方法种完成对excel表格字段顺序的控制,具体控制语句为:final Field[] filds = c.getDeclaredFields();//获得该类中所有的属性

这就是从底层开始导入excel的完整过程

转载于:https://www.cnblogs.com/telwanggs/p/7485352.html

WEB下的excel批量导入功能相关推荐

  1. oracle导入excel字段超过4000字符数据_产品思考:B端产品中,为什么批量导入功能很重要?...

    B端产品的重要价值是提高企业的办公效率,在企业的日常工作中批量录入数据的场景很多,所以批量导入是b端设计中很重要的一个功能.本文作者结合案例,分享了自己关于B端产品批量导入功能的思考. 在做b端产品的 ...

  2. Java实现Excel批量导入数据库

    springboot实现Excel批量导入数据库 前言:项目开发中最容易碰到的需求即将Excel数据批量上传到数据库中存储 -> Java实现,Excel数据表,MySQL数据库,具体步骤如下- ...

  3. excel批量导入数据

    这个功能也是我以前项目中经常用到的,感觉很实用,必须拿来分享下: excel进行批量导入数据,结合struts2+ajax 导入的视图:batchAdd.ftl(视图无关紧要的,可以换成其他任何视图, ...

  4. SpringMVC框架通过Excel批量导入数据

    文章目录 SpringMVC框架通过Excel批量导入数据 1.导入需要的jar包 2.配置文件 3.创建Java对象类 4.解析Excel表格数据的工具类 5.前端请求 6.Controller处理 ...

  5. Springboot Excel批量导入数据

    POI处理Excel <!-- poi处理excel --><dependency><groupId>org.apache.poi</groupId>& ...

  6. excel批量导入图片的方法和例子

    内容提要:文章分享了三个excel批量导入图片的典型案例:查找对应姓名的照片.批量导入图片等等,并提供附件下载.对Excel感兴趣的朋友可加 Excel学习交流群:284029260(www.itbl ...

  7. excel宏转txt替换强制换行符_三个步骤学会用EXCEL批量导入anki题库

    Anki真的是个好用到不想推荐给朋友的软件,本人最近准备刷个新题库,找了一上午找不到原来教我EXCEL导入anki的网页,为了防止我自己过段时间又忘了应该怎么导入,我写了这个教程,写都写了,就顺手发出 ...

  8. 订餐系统之Excel批量导入

    批量导入现在基本已经成为各类系统的标配了,当前,我们订餐系统也不例外,什么商家呀.商品呀.优惠码之类的,都少不了.毕竟嘛,对非开发人员来说,看到Excel肯定比看到很多管理系统还是要亲切很多的.这里, ...

  9. 【转帖】Java实现Excel批量导入数据

    这篇文章主要为大家详细介绍了Java实现Excel批量导入数据,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 Excel的批量导入是很常见的功能,这里采用Jxl实现,数 ...

最新文章

  1. linux rpm目录,Linux修改RPM的安装目录的方法
  2. c#_限制TextBox输入类型仅可为“-” “.” 数字
  3. 编写高效的Android代码
  4. 快速找到message toast弹出的application代码位置
  5. C++--Qt使用Http协议
  6. 使用supervisord 来守护 nginx进程
  7. notion函数_Notion使用指南 | Database篇
  8. java 雅思_基于JAVA的雅思考试管理系统的设计与实现(SSH,MySQL)(含录像)
  9. iphonex价格_正二品:帮你解读IphoneX回收价,为何二手市场iphoneX依旧吃香
  10. 多态加opp内置函数
  11. mysql study_mysql_study_3
  12. 利用Python将excel或csv文件导入到mysql数据库中
  13. AutoCAD中的Spline曲线算法分析(二)
  14. Android免费加固加壳加密
  15. QlikView sheet权限
  16. 【SLAM】2019浙大SLAM暑期学校--刘浩敏《集束调整》学习记录
  17. 基于爬虫爬取的数据,完成数据展示网站
  18. Cisco IPCC概述
  19. ZUCC_计算机网络实验_实验09 网络基本命令
  20. 企业微信公告可以发布图片吗?

热门文章

  1. Linux 文件 目录
  2. (17)vivado2019.1不能生成bit文件解决方法(学无止境)
  3. (28)System Verilog设计UART发送
  4. 一定质量的封闭气体被压缩后_单螺杆压缩机
  5. excel两列相同匹配第三列_Vlookup函数解决Excel大量数据匹配问题
  6. 基于modelsim的十个Verilog入门试验程序(1)(7人表决器+算术逻辑单元)—程序+测试代码+波形+结果分析
  7. Linux基本命令介绍
  8. java修饰方法_java接口中方法、属性修饰符详解
  9. 北京工业大学c语言期末考试题,北京工业大学C语言部分练习答案.docx
  10. linux下qt制作日历,课内资源