java poi实现excel中的数据导入到mysql数据库中,例如excel中有id,name,age。将其导入到数据库中。

要详细代码,最好能够运行的,不要代码片段。纯java,不要jsp的。谢谢!

package bis.excel;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import jxl.Sheet;
import jxl.Workbook;
public class Excel {
 
 @SuppressWarnings("unchecked")
 public List addCust(File file){
  List list=new ArrayList();
  List list2=new ArrayList();
  Workbook rwb=null;
  try {
   List list1=new ArrayList();
   
   InputStream is=new FileInputStream(file);//读取文件(所要导入excel的保存目录,如:f:\\a.xls)
   rwb=Workbook.getWorkbook(is);//创建工作薄
   Sheet rs=rwb.getSheet(0);//读取excel中的第一个工作表(默认新建excel下面有sheet1,sheet2,sheet3)
   int cellCount=rs.getColumns();//获取Sheet表中所包含的总列数
   int rowCount=rs.getRows();//获取Sheet表中所包含的总行数
   for(int m=0;m<cellCount;m++){//将表的第一行数据保存到list1中(列名),即id,name ,age
    String cell=rs.getCell(m,0).getContents();
    list1.add(cell);
   }
   for(int i=1;i<rowCount;i++){//获取值
    Map map=new TreeMap();
    for(int j=0;j<cellCount;j++){    
     map.put(list1.get(j),rs.getCell(j,i).getContents());//将值以键/值对方式保存到map对象中即(id:1,name:zhangsan,age:18)
    } 
    list.add(map);//将值保存到list中
    //System.out.println(list.get(i-1));
   }
   
   list2.add(list1);//将表头(id,name,age)保存到list2中
   list2.add(list);//将值保存到list2中
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }finally{
   rwb.close();
  }
  return list2; 
 }
 public void tosql(){
  List list=addCust(file);//file:所要导入excel的保存目录,如:f:\\a.xls
  Map map=new HashMap();
  String[] values=new String[ls2.size()];//保存id,name,age 值
  for (int i =0; i < ls2.size(); i++) { 
   map=(Map)ls2.get(i);
   String value="";
    id=(String)map.get("id");
   name=(String)map.get("name");
   age=(String)map.get("age");
   value=id+";"+name+";"+age;
   values[i]=value;
 }
 }
}
这是段读取excel表数据的代码,在tosql方法中调用addCust方法读取excel表,最后把所有行的id,name,age值保存到了values数组中,也可以保存到类中,如果你会对数据库操作的话,
后面的你自己弄下就行了,不会的话留言,我晚上在告诉你,我现在上班呢,时间有限,只能写这么多了

追问

谢谢!写完整吧。不会。

追答package util;

public class User {

 private String id;

 private String name;

 private String age;

 public String getId() {

  return id;

 }

 public void setId(String id) {

  this.id = id;

 }

 public String getName() {

  return name;

 }

 public void setName(String name) {

  this.name = name;

 }

 public String getAge() {

  return age;

 }

 public void setAge(String age) {

  this.age = age;

 }

  

}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-06-05
直接用Navicat for MySQL自带的导入功能不行吗追问

java实现,谢谢!

相似回答