在程序中如何正确的添加一个EXCEL的SHEET?

daily 2001-07-31 09:44:57
我从EXCEL8.OLB中导出了一个类Worksheets,发现了其中有一个Add函数:
LPDISPATCH Add(const VARIANT& Before, const VARIANT& After, const VARIANT& Count, const VARIANT& Type);,
使用它可以添加上一个SHEET,但添加完之后却总出现非法操作。
我想请问一下这个函数的几个参数都是什么意思?它们的用法是什么?希望大家指点!
...全文
633 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
wyongyong 2002-03-15
  • 打赏
  • 举报
回复
在开始加
#include"comdef"
然后用
sheets.add(vtMissing,vtMissing,vtMissing,vtMissing)
lbqsv 2001-08-13
  • 打赏
  • 举报
回复
解决了没有?
lbqsv 2001-08-07
  • 打赏
  • 举报
回复
CMyVariant是COleVariant的派生类
daily 2001-08-05
  • 打赏
  • 举报
回复
大家都来关注一下我提的问题可以吗?
daily 2001-08-04
  • 打赏
  • 举报
回复
能再给一些提示吗?
daily 2001-08-04
  • 打赏
  • 举报
回复
TO:lbqsv(vc_lover)
请问你的代码当中的CMyVariant是COleVariant的派生类吗?另外这些代码在运行时出现的是类ADD方法无效?很奇怪。还有什么值得注意的地方吗?有什么例子程序吗?
非常感谢你的提示!
lbqsv 2001-08-03
  • 打赏
  • 举报
回复
_Application excelApp;
excelApp.CreateDispatch("Excel.Application.8");
if(excelApp.m_lpDispatch==NULL)
{
MessageBox("Error create excel application");
return;
}
Workbooks wbs;
wbs.AttachDispatch(excelApp.GetWorkbooks());
_Workbook tempWb,DayWb;
CMyVariant Template;
Template.vt=VT_I2;
Template.iVal=-4167;
DayWb.AttachDispatch(wbs.Add(Template));
Worksheets wss;
wss.AttachDispatch(DayWb.GetWorksheets());
CMyVariant before,after,count,type;
after.vt=VT_DISPATCH;
COleVariant index(1L);
after.pdispVal=wss.GetItem(index);
count.vt=VT_I2;
count.iVal=1;
LPDISPATCH pws1,pws2;
pws1=wss.Add(before,after,count,type);
after.pdispVal->Release();
index.lVal=2L;
after.pdispVal=wss.GetItem(index);
pws2=wss.Add(before,after,count,type);
after.pdispVal->Release();

LPDISPATCH Add(const VARIANT& Before, const VARIANT& After, const VARIANT& Count, const VARIANT& Type);,
before,after 指要插入的worksheet的前面。后面的worksheet,这个位置关系可以在
excel中的下面的tab页上看出来,count指要插入的个数,type可不设。
它们都是Variant变体类型,相当于vb中的变体(实际上vb可能就是这样实现的)
老出错的原因可能是没有这一行
after.pdispVal->Release();
是因为wss.Add(before,after,count,type);内部对after.pdispVal->AddRef()了。


写出来与大家分享,有不对之处欢迎指正。
wangfeng 2001-08-03
  • 打赏
  • 举报
回复
你开心,我开心~~~~
大家今天都有好运气~~~~
daily 2001-08-03
  • 打赏
  • 举报
回复
看了看其中的帮助,但还是不太明白,能提供一下相关的程序代码吗?
ExitWindows 2001-07-31
  • 打赏
  • 举报
回复
up
AlphaOne 2001-07-31
  • 打赏
  • 举报
回复
启动word,工具->宏->visual basic 编辑器
按F2查看所有的对象,
选中某对象后 右键菜单->帮助
daily 2001-07-31
  • 打赏
  • 举报
回复
虚心向大家学习,请大家关注我提的问题
daily 2001-07-31
  • 打赏
  • 举报
回复
再问一个弱智问题:VBA的帮助在哪里能查到?我因为刚开始接触这方面的东西,所以还不是很懂。
AlphaOne 2001-07-31
  • 打赏
  • 举报
回复
可以查查VBA的帮助
通过java操作excel表格的工具类库   支持Excel 95-2000的所有版本   生成Excel 2000标准格式   支持字体、数字、日期操作   能够修饰单元格属性   支持图像和图表   应该说以上功能已经能够大致满足我们的需要。最关键的是这套API是纯Java的,并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。另外需要说明的是,这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。   搭建环境   将下载后的文件解包,得到jxl.jar,放入classpath,安装就完成了。   (很大总是不能很好的加载,我想补充一下:把你下载好的JXL.JAR包放入D:\JAVA\jre\lib\ext(我的是JDK1.6)就OK了。我相信在配置TOMCAT时也需要把相关的三个包放到这里面。)   基本操作   一、创建文件   拟生成一个名为“测试数据.xls”的Excel文件,其一个工作表被命名为“第一页”,大致效果如下:   代码(CreateXLS.java):   //生成Excel的类   import java.io.*;   import jxl.*;   import jxl.write.*;   public class CreateXLS   {   public static void main(String args[])   {   try   {   //打开文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”));   //生成名为“第一页”的工作表,参数0表示这是第一页   WritableSheet sheet=book.createSheet(“第一页”,0);   //在Label对象的构造子指名单元格位置是第一列第一行(0,0)   //以及单元格内容为test   Label label=new Label(0,0,”test”);   //将定义好的单元格添加到工作表   sheet.addCell(label);   /*生成一个保存数字的单元格   必须使用Number的完整包路径,否则有语法歧义   单元格位置是第二列,第一行,值为789.123*/   jxl.write.Number number = new jxl.write.Number(1,0,789.123);   sheet.addCell(number);   //写入数据并关闭文件   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   编译执行后,会在当前位置产生一个Excel文件。   三、读取文件   以刚才我们创建的Excel文件为例,做一个简单的读取操作,程序代码如下:   //读取Excel的类   import java.io.*;   import jxl.*;   public class ReadXLS   {   public static void main(String args[])   {   try   {   Workbook book=   Workbook.getWorkbook(new File(“测试.xls”));   //获得第一个工作表对象   Sheet sheet=book.getSheet(0);   //得到第一列第一行的单元格   Cell cell1=sheet.getCell(0,0);   String result=cell1.getContents();   System.out.println(result);   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   程序执行结果:test   四、修改文件   利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,其他操作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件添加一个工作表:   //修改Excel的类,添加一个工作表   import java.io.*;   import jxl.*;   import jxl.write.*;   public class UpdateXLS   {   public static void main(String args[])   {   try   {   //Excel获得文件   Workbook wb=Workbook.getWorkbook(new File(“测试.xls”));   //打开一个文件的副本,并且指定数据写回到原文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”),wb);   //添加一个工作表   WritableSheet sheet=book.createSheet(“第二页”,1);   sheet.addCell(new Label(0,0,”第二页的测试数据”));   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   执行结果如图:   高级操作   一、 数据格式化   在Excel不涉及复杂的数据类型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。   1、 字串格式化   字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,为方便叙述,我们为每一行命令加了编号:   WritableFont font1=   new WritableFont(WritableFont.TIMES,16,WritableFont.BOLD); 或//设置字体格式为excel支持的格式 WritableFont font3=new WritableFont(WritableFont.createFont("楷体_GB2312"),12,WritableFont.NO_BOLD );① WritableCellFormat format1=new WritableCellFormat(font1); ② Label label=new Label(0,0,”data 4 test”,format1) ③ 其①指定了字串格式:字体为TIMES,字号16,加粗显示。WritableFont有非常丰富的构造子,供不同情况下使用,jExcelAPI的java-doc有详细列表,这里不再列出。 ②处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种属性,后面的单元格格式化会有更多描述。 ③处使用了Label类的构造子,指定了字串被赋予那种格式。 在WritableCellFormat类,还有一个很重要的方法是指定数据的对齐方式,比如针对我们上面的实例,可以指定:   //把水平对齐方式指定为居   format1.setAlignment(jxl.format.Alignment.CENTRE);   //把垂直对齐方式指定为居   format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);   //设置自动换行   format1.setWrap(true);   二、单元格操作   Excel很重要的一部分是对单元格的操作,比如行高、列宽、单元格合并等,所幸jExcelAPI提供了这些支持。这些操作相对比较简单,下面只介绍一下相关的API。   1、 合并单元格   WritableSheet.mergeCells(int m,int n,int p,int q);   作用是从(m,n)到(p,q)的单元格全部合并,比如:   WritableSheet sheet=book.createSheet(“第一页”,0);   //合并第一列第一行到第六列第一行的所有单元格   sheet.mergeCells(0,0,5,0);   合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。   2、 行高和列宽   WritableSheet.setRowView(int i,int height);   作用是指定第i+1行的高度,比如:   //将第一行的高度设为200   sheet.setRowView(0,200);   WritableSheet.setColumnView(int i,int width);   作用是指定第i+1列的宽度,比如:   //将第一列的宽度设为30   sheet.setColumnView(0,30);   五、操作图片   public static void write()throws Exception{   WritableWorkbook wwb=Workbook.createWorkbook(new File("c:/1.xls"));   WritableSheet ws=wwb.createSheet("Test Sheet 1",0);   File file=new File("C:\\jbproject\\PVS\\WebRoot\\weekhit\\1109496996281.png");   WritableImage image=new WritableImage(1, 4, 6, 18,file);   ws.addImage(image);   wwb.write();   wwb.close();   }   很简单和插入单元格的方式一样,不过就是参数多了些,WritableImage这个类继承了Draw,上面只是他构造方法的一种,最后一个参数不用了说了,前面四个参数的类型都是double,依次是 x, y, width, height,注意,这里的宽和高可不是图片的宽和高,而是图片所要占的单位格的个数,因为继承的Draw所以他的类型必须是double,具体里面怎么实现的我还没细看:)因为着急赶活,先完成功能,其他的以后有时间慢慢研究。以后会继续写出在使用的心得给大家。   读:   读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl的Workbook得到工作薄,用Sheet从工作薄得到工作表,用Cell得到工作表得某个单元格.   InputStream->Workbook->Sheet->Cell,就得到了excel文件的单元格   代码:   String path="c:\\excel.xls";//Excel文件URL   InputStream is = new FileInputStream(path);//写入到FileInputStream   jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄   jxl.Sheet st = wb.getSheet(0);//得到工作薄的第一个工作表   Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1   String content=cell.getContents();//getContents()将Cell的字符转为字符串   wb.close();//关闭工作薄   is.close();//关闭输入流   我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel的坐标对应.   例如A1对应(0,0),A2对应(0,1),D3对应(3,2).Excel坐标从A,1开始,jxl全部是从0开始.   还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet的所有内容.   写:   往Excel写入内容主要是用jxl.write包的类.   思路是这样的:   OutputStream<-WritableWorkbook<-WritableSheet<-Label   这里面Label代表的是写入Sheet的Cell位置及内容.   代码:   OutputStream os=new FileOutputStream("c:\\test.xls");//输出的Excel文件URL   WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄   WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表   Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容   ws.addCell(labelCF);//将Label写入sheet   Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.   WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);//设置写入字体   WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat   Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式   Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性.   现在可以写了   wwb.write();   写完后关闭   wwb.close();   输出流也关闭吧   os.close;   OK,只要把读和写结合起来,就可以在N个Excel读取数据写入你希望的Excel新表,还是比较方便的.   下面是程序一例:   程序代码:sql = "select * from tablename";   rs = stmt.executeQuery(sql);   //新建Excel文件   String filePath=request.getRealPath("aaa.xls");   File myFilePath=new File(filePath);   if(!myFilePath.exists())   myFilePath.createNewFile();   FileWriter resultFile=new FileWriter(myFilePath);   PrintWriter myFile=new PrintWriter(resultFile);   resultFile.close();   //用JXL向新建的文件添加内容   OutputStream outf = new FileOutputStream(filePath);   jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(outf);   jxl.write.WritableSheet ws = wwb.createSheet("sheettest", 0);   int i=0;   int j=0;   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,0,rs.getMetaData().getColumnName(k+1)));   }   while(rs.next()){   out.println(rs.getMetaData().getColumnCount());   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,j+i+1,rs.getString(k+1)));   }   i++;   }   wwb.write();   wwb.close();   }catch(Exception e){e.printStackTrace();}   finally{   rs.close();   conn.close();   }   response.sendRedirect("aaa.xls");
jxl.jar  jxl.jar   通过java操作excel表格的工具类库   支持Excel 95-2000的所有版本   生成Excel 2000标准格式   支持字体、数字、日期操作   能够修饰单元格属性   支持图像和图表   应该说以上功能已经能够大致满足我们的需要。最关键的是这套API是纯Java的,并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。另外需要说明的是,这套API对图形和图表的支持很有限,而且仅仅识别PNG格式。   搭建环境   将下载后的文件解包,得到JXL.JAR,放入classpath,安装就完成了。如果包不能正常的加载,可以把你下载好的JXL.JAR包放入D:\JAVA\jre\lib\ext(我的是JDK1.6)就OK了。我相信在配置TOMCAT时也需要把相关的三个包放到这里面。   基本操作   一、创建文件   拟生成一个名为“测试数据.xls”的Excel文件,其一个工作表被命名为“第一页”,大致效果如下:   代码(CreateXLS.java):   //生成Excel的类   import java.io.*;   import jxl.*;   import jxl.write.*;   public class CreateXLS   {   public static void main(String args[])   {   try   {   //打开文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”));   //生成名为“第一页”的工作表,参数0表示这是第一页   WritableSheet sheet=book.createSheet(“第一页”,0);   //在Label对象的构造子指名单元格位置是第一列第一行(0,0)   //以及单元格内容为test   Label label=new Label(0,0,”test”);   //将定义好的单元格添加到工作表   sheet.addCell(label);   /*生成一个保存数字的单元格   必须使用Number的完整包路径,否则有语法歧义   单元格位置是第二列,第一行,值为789.123*/   jxl.write.Number number = new jxl.write.Number(1,0,789.123);   sheet.addCell(number);   //写入数据并关闭文件   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   编译执行后,会在当前位置产生一个Excel文件。   三、读取文件   以刚才我们创建的Excel文件为例,做一个简单的读取操作,程序代码如下:   //读取Excel的类   import java.io.*;   import jxl.*;   public class ReadXLS   {   public static void main(String args[])   {   try   {   Workbook book=   Workbook.getWorkbook(new File(“测试.xls”));   //获得第一个工作表对象   Sheet sheet=book.getSheet(0);   //得到第一列第一行的单元格   Cell cell1=sheet.getCell(0,0);   String result=cell1.getContents();   System.out.println(result);   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   程序执行结果:test   四、修改文件   利用jExcelAPI可以修改已有的Excel文件,修改Excel文件的时候,除了打开文件的方式不同之外,其他操作和创建Excel是一样的。下面的例子是在我们已经生成的Excel文件添加一个工作表:   //修改Excel的类,添加一个工作表   import java.io.*;   import jxl.*;   import jxl.write.*;   public class UpdateXLS   {   public static void main(String args[])   {   try   {   //Excel获得文件   Workbook wb=Workbook.getWorkbook(new File(“测试.xls”));   //打开一个文件的副本,并且指定数据写回到原文件   WritableWorkbook book=   Workbook.createWorkbook(new File(“测试.xls”),wb);   //添加一个工作表   WritableSheet sheet=book.createSheet(“第二页”,1);   sheet.addCell(new Label(0,0,”第二页的测试数据”));   book.write();   book.close();   }catch(Exception e)   {   System.out.println(e);   }   }   }   高级操作   一、 数据格式化   在Excel不涉及复杂的数据类型,能够比较好的处理字串、数字和日期已经能够满足一般的应用。   1、字串格式化   字符串的格式化涉及到的是字体、粗细、字号等元素,这些功能主要由WritableFont和WritableCellFormat类来负责。假设我们在生成一个含有字串的单元格时,使用如下语句,为方便叙述,我们为每一行命令加了编号:   WritableFont font1= new WritableFont(WritableFont.TIMES,16,WritableFont.BOLD); 或//设置字体格式为excel支持的格式 WritableFont font3=new WritableFont(WritableFont.createFont("楷体 _GB2312"),12,WritableFont.NO_BOLD );   ① WritableCellFormat format1=new WritableCellFormat(font1);   ② Label label=new Label(0,0,”data 4 test”,format1);   ③ 其①指定了字串格式:字体为TIMES,字号16,加粗显示。   WritableFont有非常丰富的构造子,供不同情况下使用,jExcelAPI的 java-doc有详细列表,这里不再列出。   ②处代码使用了WritableCellFormat类,这个类非常重要,通过它可以指定单元格的各种属性,后面的单元格格式化会有更多描述。 ③处使用了Label类的构造子,指定了字串被赋予那种格式。在WritableCellFormat类,还有一个很重要的方法是指定数据的对齐方式,比如针对我们上面的实例,可以指定:   //把水平对齐方式指定为居   format1.setAlignment(jxl.format.Alignment.CENTRE);   //把垂直对齐方式指定为居   format1.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);   //设置自动换行   format1.setWrap(true);   二、单元格操作   Excel很重要的一部分是对单元格的操作,比如行高、列宽、单元格合并等,所幸jExcelAPI提供了这些支持。这些操作相对比较简单,下面只介绍一下相关的API。   1、 合并单元格   WritableSheet.mergeCells(int m,int n,int p,int q);   作用是从(m,n)到(p,q)的单元格全部合并,比如:   WritableSheet sheet=book.createSheet(“第一页”,0);   //合并第一列第一行到第六列第一行的所有单元格   sheet.mergeCells(0,0,5,0);   合并既可以是横向的,也可以是纵向的。合并后的单元格不能再次进行合并,否则会触发异常。   2、 行高和列宽   WritableSheet.setRowView(int i,int height);   作用是指定第i+1行的高度,比如:   //将第一行的高度设为200   sheet.setRowView(0,200);   WritableSheet.setColumnView(int i,int width);   作用是指定第i+1列的宽度,比如:   //将第一列的宽度设为30   sheet.setColumnView(0,30);   五、操作图片   public static void write()throws Exception{   WritableWorkbook wwb=Workbook.createWorkbook(new File("c:/1.xls"));   WritableSheet ws=wwb.createSheet("Test Sheet 1",0);   File file=new File("C:\\jbproject\\PVS\\WebRoot\\weekhit\\1109496996281.png");   WritableImage image=new WritableImage(1, 4, 6, 18,file);   ws.addImage(image);   wwb.write();   wwb.close();   }   很简单和插入单元格的方式一样,不过就是参数多了些,WritableImage这个类继承了 Draw,上面只是他构造方法的一种,最后一个参数不用说了,前面四个参数的类型都是double,依次是 x, y, width, height,注意,这里的宽和高可不是图片的宽和高,而是图片所要占的单位格的个数,因为继承的Draw所以他的类型必须是double,具体里面怎么实现的我还没细看:)因为着急赶活,先完成功能,其他的以后有时间慢慢研究。以后会继续写出在使用的心得给大家。   读:   读的时候是这样的一个思路,先用一个输入流(InputStream)得到Excel文件,然后用jxl的Workbook得到工作薄,用Sheet从工作薄得到工作表,用Cell得到工作表得某个单元格。   InputStream->Workbook->Sheet->Cell,就得到了excel文件的单元格   代码:   String path="c:\\excel.xls";//Excel文件URL   InputStream is = new FileInputStream(path);//写入到FileInputStream   jxl.Workbook wb = Workbook.getWorkbook(is); //得到工作薄   jxl.Sheet st = wb.getSheet(0);//得到工作薄的第一个工作表   Cell cell=st.getCell(0,0);//得到工作表的第一个单元格,即A1   String content=cell.getContents();//getContents()将Cell的字符转为字符串   wb.close();//关闭工作薄   is.close();//关闭输入流   我们可以通过Sheet的getCell(x,y)方法得到任意一个单元格,x,y和excel的坐标对应.   例如A1对应(0,0),A2对应(0,1),D3对应(3,2).Excel坐标从A,1开始,jxl全部是从0开始.   还可以通过Sheet的getRows(),getColumns()方法得到行数列数,并用于循环控制,输出一个sheet的所有内容.   写:   往Excel写入内容主要是用jxl.write包的类。   思路是这样的:   OutputStream<-WritableWorkbook<-WritableSheet<-Label   这里面Label代表的是写入Sheet的Cell位置及内容。   代码:   OutputStream os=new FileOutputStream("c:\\test.xls");//输出的Excel文件URL   WritableWorkbook wwb = Workbook.createWorkbook(os);//创建可写工作薄   WritableSheet ws = wwb.createSheet("sheet1", 0);//创建可写工作表   Label labelCF=new Label(0, 0, "hello");//创建写入位置和内容   ws.addCell(labelCF);//将Label写入sheet   Label的构造函数Label(int x, int y,String aString)xy意同读的时候的xy,aString是写入的内容.   WritableFont wf = new WritableFont(WritableFont.TIMES, 12, WritableFont.BOLD, false);//设置写入字体   WritableCellFormat wcfF = new WritableCellFormat(wf);//设置CellFormat   Label labelCF=new Label(0, 0, "hello");//创建写入位置,内容和格式   Label的另一构造函数Label(int c, int r, String cont, CellFormat st)可以对写入内容进行格式化,设置字体及其它的属性.   现在可以写了   wwb.write();   写完后关闭   wwb.close();   输出流也关闭吧   os.close;   OK,只要把读和写结合起来,就可以在N个Excel读取数据写入你希望的Excel新表,还是比较方便的。   下面是程序一例:   程序代码:sql = "select * from tablename";   rs = stmt.executeQuery(sql);   //新建Excel文件   String filePath=request.getRealPath("aaa.xls");   File myFilePath=new File(filePath);   if(!myFilePath.exists())   myFilePath.createNewFile();   FileWriter resultFile=new FileWriter(myFilePath);   PrintWriter myFile=new PrintWriter(resultFile);   resultFile.close();   //用JXL向新建的文件添加内容   OutputStream outf = new FileOutputStream(filePath);   jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(outf);   jxl.write.WritableSheet ws = wwb.createSheet("sheettest", 0);   int i=0;   int j=0;   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,0,rs.getMetaData().getColumnName(k+1)));   }   while(rs.next()){   out.println(rs.getMetaData().getColumnCount());   for (int k = 0; k < rs.getMetaData().getColumnCount(); k++) {   ws.addCell(new Label(k,j+i+1,rs.getString(k+1)));   }   i++;   }   wwb.write();   wwb.close();   }catch(Exception e){e.printStackTrace();}   finally{   rs.close();   conn.close();   }   response.sendRedirect("aaa.xls");
java_POI教程.pdf java的POI操作Excel文件.doc POI_API帮助文档.chm poi-bin-3.9-20121203.tar.gz poi帮助.docx POI文帮助文档.pdf poi文教程.doc第一章 POI简介 实际的开发,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。 workbook(HSSFWorkbook),一个workbook可以有多个sheet(HSSFSheet)组成,一个sheet是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。 POI可以到www.apache.org下载到。实际运行时,需要有poi包就可以了。HSSF提供给用户使用的对象在rg.apache.poi.hssf.usermodel包,主要部分包括Excel对象,样式和格式,还有辅助操作。有以下几种对象: HSSFWorkbook excel的文档对象 HSSFSheet excel的表单 HSSFRow excel的行 HSSFCell excel的格子单元 HSSFFont excel字体 HSSFDataFormat 日期格式 在poi1.7才有以下2项: HSSFHeader sheet头 HSSFFooter sheet尾(只有打印的时候才能看到效果) 和这个样式 HSSFCellStyle cell样式 辅助操作包括 HSSFDateUtil 日期 HSSFPrintSetup 打印 HSSFErrorConstants 错误信息表 以下可能需要使用到如下的类 import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import org.apache.poi.hssf.usermodel.HSSFDataFormat; import org.apache.poi.hssf.usermodel.HSSFFont; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.hssf.util.HSSFColor; 先看poi的examples包提供的最简单的例子,建立一个空xls文件。 import java.io.FileOutputStream; import java.io.IOException; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class ExcelSample1 { public static void main(String[] args) throws IOException { //创建一个excel文件 HSSFWorkbook wb= new HSSFWorkbook(); FileOutputStream fileOut= new FileOutputStream("c:\\workbook.xls"); // FileOutputStream fileOut= new FileOutputStream("c:/workbook.xls"); wb.write(fileOut); fileOut.close(); } } 通过这个例子,我们在c盘下建立的是一个空白的xls文件(不是空文件)。在此基础上,我们可以进一步看其它的例子。 import org.apache.poi.hssf.usermodel.*; import java.io.FileOutputStream; import java.io.IOException; public class CreateCells { public static void main(String[] args) throws IOException { HSSFWorkbook wb = new HSSFWorkbook(); //建立新HSSFWorkbook对象 HSSFSheet sheet = wb.createSheet("new sheet"); //建立新的sheet对象 HSSFRow row = sheet.createRow((short)0); //在sheet里创建一行,参数为行号(第一行,此处可想象成数组) HSSFCell cell = row.createCell((short)0); //在row里建立新cell(单元格),参数为列号(第一列) cell.setCellvalue(1); //设置cell的整数类型的值 row.createCell((short)1).setCellvalue(1.2); //设置cell浮点类型的值 row.createCell((short)2).setCellvalue("test"); //设置cell字符类型的值 row.createCell((short)3).setCellvalue(true); //设置cell布尔类型的值 HSSFCellStyle cellStyle = wb.createCellStyle(); //建立新的cell样式 cellStyle.setDataFormat(HSSFDataFormat. getBuiltinFormat("m/d/yy h:mm")); //设置cell样式为定制的日期格式 HSSFCell dCell =row.createCell((short)4); dCell.setCellvalue(new Date()); //设置cell为日期类型的值 dCell.setCellStyle(cellStyle); //设置该cell日期的显示格式 HSSFCell csCell =row.createCell((short)5); csCell.setEncoding(HSSFCell.ENCODING_UTF_16); //设置cell编码解决文高位字节截断 csCell.setCellvalue("文测试_Chinese Words Test"); //设置西文结合字符串 row.createCell((short)6).setCellType(HSSFCell.CELL_TYPE_ERROR); //建立错误cell FileOutputStream fileOut = new FileOutputStream("workbook.xls"); wb.write(fileOut); fileOut.close(); } } 通过这个例子,我们可以清楚的看到xls文件从大到小包括了HSSFWorkbook HSSFSheet HSSFRow HSSFCell这样几个对象。我们可以在cell设置各种类型的值。 尤其要注意的是如果你想正确的显示非欧美的字符时,尤其象日韩这样的语言,必须设置编码为16位的即是HSSFCell.ENCODING_UTF_16,才能保证字符的高8位不被截断而引起编码失真形成乱码。 其他测试可以通过参考examples包的测试例子掌握poi的详细用法,包括字体的设置,cell大小和低纹的设置等。需要注意的是POI是一个仍然在完善的公开代码的项目,所以有些功能正在不断的扩充。 感觉上面的操作比较的繁琐,然后就自己写了一个方法。这个方法不需要事先创建row和cell,直接进行cteateCell就可以了,在程序会自动进行判断,如果不存在的话会创建。 private static void cteateCell(HSSFWorkbook wb,HSSFRow row,short col,short align,String val){ HSSFCell cell = row.createCell(col); cell.setEncoding(HSSFCell.ENCODING_UTF_16); cell.setCellValue(val); HSSFCellStyle cellstyle = wb.createCellStyle(); cellstyle.setAlignment(align); cell.setCellStyle(cellstyle); } 对里面的几个参数的说明: short col 应该是你的cell单元格的位置也就是列号; short align 应该是你的对齐方式; String val 应该是你单元格里面要添加的值; 具体的调用如下: HSSFRow row = sheet.createRow((short)1); cteateCell(wb,row,(short)0,HSSFCellStyle.ALIGN_CENTER_SELECTION,"SampleID"); 在上边的例子里我们看到了要设置一个单元格里面信息的格式(例如,要将信息居)设置的操作如下: HSSFCellStyle cellstyle = wb.createCellStyle(); cellstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER_SELECTION); cell.setCellStyle(cellstyle); 还有我们我们经常会用到的合并单元格,在这里我们也有这样的操作,代码如下: sheet.addMergedRegion(new Region(1,(short)1,2,(short)4)); 这里面我们还要介绍一个经常会遇到的问题,就是怎么来冻结一个窗口。poi也为我们集成了这样的事情了。代码如下: sheet.createFreezePane(1,2);  在这里我们需要注意的是 一、 该方法是在一个具体的sheet里面来进行操作。 二、 方法createFreezepane;有2个参数。前一个参数代表列;后一个参数代表行。 上边的代码对应的excel文件如下: 我么在画面上看到了明显的两条黑线,这就是冻结的窗口。 然后我们来看一个完整的STRUTS的小例子,在这个例子里面我们要做的事情是要模拟移动公司的网上营业厅里面的一个功能,我们要把一个客户当月的通话记录和各种信息查询出来,并且生成一张excel报表。首先,我们来看一下网上效果的截图。

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧