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

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali