Struts2、jquery OCUpload、Apache POI、pinyin4J实现excel数据导入功能

本文主要是介绍Struts2、jquery OCUpload、Apache POI、pinyin4J实现excel数据导入功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Struts2、jquery OCUpload、Apache POI、pinyin4J实现excel数据导入功能

  • 一、前端实现
    • 1.1 将js文件引入页面
    • 1.2 在页面中提供任意一个元素
    • 1.3 调用插件提供的upload方法,动态修改HTML页面元素
    • 1.4 效果展示
  • 二、服务端实现
    • 2.1 接收客户端上传的文件
    • 2.2 解析提交的xml文件

excel数据导入,提交图片或文件等式每一个平台必备的功能,本文以导入excel数据为例,将述在ssh框架下的数据导入功能的实现

一、前端实现

前端数据导入功能采用的是jquery OCUpload方法,即基于jQuery的OCUpload(One Click Upload)一键上传插件,优点是简单易实现

1.1 将js文件引入页面

jquery-1.8.3.js
jquery.ocupload-1.1.2.js

1.2 在页面中提供任意一个元素

<input type="button" name="regionFile" id="myButton" value="导入"/>
任意元素即可,不局限于是按钮

1.3 调用插件提供的upload方法,动态修改HTML页面元素

<script type="text/javascript">$(function(){//页面加载完成后,调用插件的upload方法,动态修改了HTML页面元素$("#myButton").upload({action:'xxx.action',name:'myFile'});});
</script>

1.4 效果展示

此时可以在浏览器中通过查看页面元素看到自动补充的元素的信息
在这里插入图片描述

二、服务端实现

2.1 接收客户端上传的文件

Struts2框架可以通过属性驱动直接接收前端页面传递的文件
注意:属性驱动的名称一定要和提交的name属性名一样

//属性驱动,接收上传的文件private File regionFile;public void setRegionFile(File regionFile) {this.regionFile = regionFile;}

2.2 解析提交的xml文件

采用Apache提供的POI技术
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能
对应的包有:

import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Row;

实现代码如下:

	public String importXls() throws Exception{List<Region> regionList = new ArrayList<Region>();//使用POI解析Excel文件HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(regionFile));//根据名称获得指定Sheet对象HSSFSheet hssfSheet = workbook.getSheet("Sheet1");//遍历每一行,取出其中的值,存到list集合中for (Row row : hssfSheet) {int rowNum = row.getRowNum();//第一行为标题行,不要if(rowNum == 0){continue;}//取出每行的数据String id = row.getCell(0).getStringCellValue();String province = row.getCell(1).getStringCellValue();String city = row.getCell(2).getStringCellValue();String district = row.getCell(3).getStringCellValue();String postcode = row.getCell(4).getStringCellValue();//包装一个区域对象Region region = new Region(id, province, city, district, postcode, null, null, null);province = province.substring(0, province.length() - 1);city = city.substring(0, city.length() - 1);district = district.substring(0, district.length() - 1);String info = province + city + district;//pinyin4J可以将汉字生成对应的拼音,简称和全程String[] headByString = PinYin4jUtils.getHeadByString(info);String shortcode = StringUtils.join(headByString);//城市编码---->>shijiazhuangString citycode = PinYin4jUtils.hanziToPinyin(city, "");region.setShortcode(shortcode);region.setCitycode(citycode);regionList.add(region);}//调用service,批量保存regionService.saveBatch(regionList);return NONE;}

扩展:方法中使用了pinyin4J,主要是根据汉字生成对应拼音的全称和简称
简称:

String[] headByString = PinYin4jUtils.getHeadByString(info);

全称:

String citycode = PinYin4jUtils.hanziToPinyin(city, "");

这篇关于Struts2、jquery OCUpload、Apache POI、pinyin4J实现excel数据导入功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/882031

相关文章

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处