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


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);
			//城市编码---->>shijiazhuang
			String 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, "");
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值