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

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte