我想做excel的导入导出功能,主要是用POI,现在已经可以实现把指定的excel导入到指定的数据库表中,前提是我要把excel中的数据类型设置正确。
现在的思路是:读取excel,把excel的每一行填充到对应的对象中,整个工作表就是一个List<Object>,最后把List添加到数据库中
也不知道我的想法是否是对的,哪位高人指点下在实际开发中试这个样子吗?
其次我觉得我的做法有点死板,因为不同的表导入进去不一定可行,我想用一个通用的方法把不同对象的导入封装好,其中可以使用反射技术,这样可行吗?
现在的思路是:读取excel,把excel的每一行填充到对应的对象中,整个工作表就是一个List<Object>,最后把List添加到数据库中
也不知道我的想法是否是对的,哪位高人指点下在实际开发中试这个样子吗?
其次我觉得我的做法有点死板,因为不同的表导入进去不一定可行,我想用一个通用的方法把不同对象的导入封装好,其中可以使用反射技术,这样可行吗?
解决方案 »
- 如何用mule对服务进行监控
- 小白的问题,编码格式
- ejb菜鸟,有个问题很困惑,求助
- google退出。言-论-自-由
- TOMCAT发布项目出现这个警告,大家看看是什么原因呢?
- QQ群:813562,欢迎加入一起学习交流jsp&struts技术!
- C:\>ant java.lang.InstantiationException: org.apache.tools.ant.Main
- 哪位能给我指点一下CLASSPATH的设置方法(在线等待==在线结贴)
- 关于struts2 序列化json的问题
- hibernate登录在dao中怎么写
- 求助----关于乱码处理的问题
- Acegi 中的角色必须以ROLE_开始吗
若设置不正确,就拒绝导入且给个格式错误提示就行了.
import java.io.InputStream;
import java.util.Vector;
import java.io.FileInputStream;
import jxl.Workbook;public class Test2 {
public static void main(String [] args){
ReadExcel("c://20060818104025_50101_Merchant.xls");
}
public Test2() {
}
/*
* 方法名:ReadExcel
* 参数:filePath为Execl文件的绝对路径
* 用途:读取Execl数据,放在数组中返回
*返回类型:Vector
*
* */
public static Vector ReadExcel(String filePath)
{
Vector v = new Vector();
Workbook rwb = null;
try
{
InputStream is = new FileInputStream(filePath);
rwb = Workbook.getWorkbook(is);
// 获取第一张Sheet表
Sheet rs = rwb.getSheet(0);
for (int k = 0; k < rs.getRows(); k++)
{
for (int j = 0; j < rs.getColumns(); j++)
{
System.out.println(rs.getCell(j, k).getContents());
v.add(rs.getCell(j, k).getContents());
}
}
rwb.close();
}
catch (Exception e)
{
e.printStackTrace();
}
return v;
}}2.public class Test1 {
public static void main(String[] args) {
jxl.Workbook rwb = null;
try{
//构建Workbook对象, 只读Workbook对象
//直接从本地文件创建Workbook
//从输入流创建Workbook
InputStream is = new FileInputStream("E:/project/test/jxlrwtest.xls");
rwb = Workbook.getWorkbook(is); //Sheet(术语:工作表)就是Excel表格左下角的Sheet1,Sheet2,Sheet3但在程序中
//Sheet的下标是从0开始
//获取第一张Sheet表
Sheet rs = rwb.getSheet(0);
//获取Sheet表中所包含的总列数
int rsColumns = rs.getColumns();
//获取Sheet表中所包含的总行数
int rsRows = rs.getRows();
//获取指定单元格的对象引用
for(int i=0;i<rsRows;i++){
for(int j=0;j<rsColumns;j++){
Cell cell = rs.getCell(j,i);
System.out.print(cell.getContents()+" ");
}
System.out.println();
}
//利用已经创建的Excel工作薄创建新的可写入的Excel工作薄
jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File("E:/project/test/test2.xls"),rwb);
//读取第一张工作表
jxl.write.WritableSheet ws = wwb.getSheet(0); //获得第一个单元格对象
jxl.write.WritableCell wc = ws.getWritableCell(0, 0);
//判断单元格的类型, 做出相应的转化
if (wc.getType() == CellType.LABEL) {
Label l = (Label) wc;
l.setString("The value has been modified.");
}
//写入Excel对象
wwb.write();
wwb.close(); }catch(Exception e){
e.printStackTrace();
}
finally{
//操作完成时,关闭对象,释放占用的内存空间
rwb.close(); }
}
}