vc操作excel程序退出的问题

在完成公司任务,使用VC与Excel交互生成并打印结账单时,遇到速度慢和程序退出问题。通过使用安全数组提高读写效率,使用Book的Close方法避免确认对话框,并确保在关闭Excel前释放所有对象,尤其是Excel隐性创建的对象,如GetRange等函数产生的对象。避免使用强制杀死Excel进程的方法,以保证程序的正确退出和性能提升。
摘要由CSDN通过智能技术生成
       公司给了我一个任务,用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进程的文章其实是不负责任的做法,对于真正的程序员来说是不可能用那些方法的.就好像修炼的人的心魔一样,一旦用了这种方法,以后自己的技术就不会再有进步了.
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值