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, "");