vc操作excel程序退出的问题
2006-01-06 10:18
381 查看
公司给了我一个任务,用excel调用模版生成结帐单并进行打印。我在努力的n天以后终于完成了。现在总结一下:
1.速度问题,vc读写excel的时候速度是很慢的,如果一个一个单元格的读写,能把你给急死。所以在读取和写入excel的时候,我使用了安全数组,这样能够将对应的数据一次性从文件中读出或者是写入。
2.关于屏蔽掉最后“确定改变文件”的对话框,用Book的close方法
//定义变量
COleVariant covTrue((short)TRUE),
covFalse((short)FALSE), covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
//关闭book, 不保存
m_Book.Close(covFalse,COleVariant(strExcelName),covOptional);
3.关于关闭excel进程的问题,即在
m_ExcelApp->Quit(); 以后系统中仍然有一个excel进程,这种情况绝对是excel中有没有释放的对象,注意这里说的对象不仅仅是自己定义的对象,在系统的运行中excel可能会自己隐性的创建一些对象,对于这些对象也一定要释放。
excel中的函数 select, m_Sheet.GetRange, chart.add等都会创建新的对象,在不用了以后一定要释放.通用的调试方法是,用创建到最后退出当中要一条一条的进行语句的添加,这样就可以保证最后系统能够顺利退出了.我的程序就是因为在copy操作之前有一个m_sheet.GetRange的函数在copy结束之后没有释放,所以造成excel进程无法释放.网上关于如果杀死excel进程的文章其实是不负责任的做法,对于真正的程序员来说是不可能用那些方法的.就好像修炼的人的心魔一样,一旦用了这种方法,以后自己的技术就不会再有进步了.
1.速度问题,vc读写excel的时候速度是很慢的,如果一个一个单元格的读写,能把你给急死。所以在读取和写入excel的时候,我使用了安全数组,这样能够将对应的数据一次性从文件中读出或者是写入。
2.关于屏蔽掉最后“确定改变文件”的对话框,用Book的close方法
//定义变量
COleVariant covTrue((short)TRUE),
covFalse((short)FALSE), covOptional((long)DISP_E_PARAMNOTFOUND, VT_ERROR);
//关闭book, 不保存
m_Book.Close(covFalse,COleVariant(strExcelName),covOptional);
3.关于关闭excel进程的问题,即在
m_ExcelApp->Quit(); 以后系统中仍然有一个excel进程,这种情况绝对是excel中有没有释放的对象,注意这里说的对象不仅仅是自己定义的对象,在系统的运行中excel可能会自己隐性的创建一些对象,对于这些对象也一定要释放。
excel中的函数 select, m_Sheet.GetRange, chart.add等都会创建新的对象,在不用了以后一定要释放.通用的调试方法是,用创建到最后退出当中要一条一条的进行语句的添加,这样就可以保证最后系统能够顺利退出了.我的程序就是因为在copy操作之前有一个m_sheet.GetRange的函数在copy结束之后没有释放,所以造成excel进程无法释放.网上关于如果杀死excel进程的文章其实是不负责任的做法,对于真正的程序员来说是不可能用那些方法的.就好像修炼的人的心魔一样,一旦用了这种方法,以后自己的技术就不会再有进步了.
相关文章推荐
- vc操作excel程序退出的问题
- 关于VC操作Excel无法退出进程的问题
- vc操作Excel保存 和Excel的退出
- 在程序中操作excel的图表的问题
- 通过vc 操作excel时避免重复定义的问题
- VC线程中操作控件,引起程序卡死的问题。
- win7 x64 下VC6的调试程序无法退出的问题
- vc屏蔽回车键解决自动退出程序问题
- 多线程 DLL 回调函数问题,当应用程序退出时,有些操作并未完成,造成程序内存泄露,如何解决呢
- win7 x64 下VC6的调试程序无法退出的问题
- VC2010操作Excel时找不到成员问题
- VC 读取操作Excel问题
- VC++操作EXCEL内存泄露问题
- Excel录入程序问题总结-操作Excel数据库、汉字转拼音问题、VS2005中文输入法全角问题
- win7 x64 下VC6的调试程序无法退出的问题解决方法
- VC操作Excel之基本操作 修改问题篇
- VC 无界面DLL调用ocx时退出出错问题
- Ado.Net操作Excel文件数据常见问题及解决
- QT的一个奇怪问题,设置了Qt::Tool后,点击弹出对话框的确定取消按钮,程序直接退出
- VC++中通过自动化将Excel嵌入程序中