package bis.excel;import java.io.File;import java.io.FileInpu" />
乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > <em>java</em> poi实现<em>excel</em>中的数

<em>java</em> poi实现<em>excel</em>中的数

作者:乔山办公网日期:

返回目录:excel表格制作




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表中所包含的总列数e799bee5baa6e59b9ee7ad94364
   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数组中,也可以保存到类中,如果你会对数据库操作的话,
后面的你自己弄下就行了,不会的话留言,我晚上在告诉你,我现在上班呢,时间有限,只能写这么多了

错了,你是要批量导入吗?
需要下载poi包
首先要先把文件转变成数据流InputStream,然后
try
{
HSSFWorkbook workbook = new HSSFWorkbook(is);
HSSFSheet sheet=workbook.getSheetAt(0);
}
catch(Exception e)
{
e.printStackTrace();
}
if(sheet==null)
{
close(streamIn);
return null;
}

int rows = sheet.getPhysicalNumberOfRows();
if(rows<=1)
{
close(streamIn);
return null;
}
HSSFRow row =null;
DecimalFormat formatter=new DecimalFormat("#");
for(int r = 1;r< rows;r++)
{
}
遍历取出,并保存

//根据excel文件,生成输入流
FileInputStream fis = new FileInputStream(new File("D:\\aa.xlsx"));
//用输入流生成poi 对象zd,以读取excel内容
//excel2007以上用XSSFWorkbook,2003用HSSFWorkbook
Workbook workbook = new XSSFWorkbook(fis);
Sheet sheet = workbook.getSheetAt(0);//取第一个sheet
String str1 = sheet.getRow(0).getCell(0).getStringCellValue();//取第一行第一列字符值
//getDateCellValue();日期类型 getNumericCellValue()数字类型;getHyperlink()超链接 等等()
//接下来 选择性插入数据库吧,明白?

相关阅读

关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网