一个简单的createdispatch的问题,请帮忙!

夫人的泡泡鱼 2013-02-04 10:56:41
COleException e
...全文
220 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
夫人的泡泡鱼 2013-02-05
  • 打赏
  • 举报
回复
还有没有其他的办法了???
wyx100 2013-02-05
  • 打赏
  • 举报
回复
换个环境试试,,,
夫人的泡泡鱼 2013-02-05
  • 打赏
  • 举报
回复
我用MFC建立了基于对话框的应用程序,在第三步勾选了Automation,建立完成。 (1)我用类向导添加了_Application 。
class _Application : public COleDispatchDriver
{……}
(2)在对话框头文件中#include "msppt.h" (3)程序自动实现初始化。
BOOL CTestDlgApp::InitInstance()
{
	// Initialize OLE libraries
	if (!AfxOleInit())
	{
		AfxMessageBox(IDP_OLE_INIT_FAILED);
		return FALSE;
	}

	AfxEnableControlContainer();
……
}
(4)在按钮响应中,添加了CreateDispatch如下:
void CTestDlgDlg::OnBtnrun() 
{
	// TODO: Add your control notification handler code here
	_Application m_app;
	COleException e;
    if(!m_app.CreateDispatch(_T("Powerpoint.Application"),&e))
    {
	e.ReportError();
        AfxMessageBox("Couldn't start PowerPoint.");
    }
    else // Make PowerPoint visible and display a message
    {
        m_app.SetVisible(TRUE);
        TRACE("PowerPoint is Running!");
    }
}
编译成功,运行时点击按钮出错: e.ReportError();//报错“无效的类字符串” 我查了网上都是使用的这个类字符串的,怎么就是无效的呢? 我用的环境是:笔记本Y470 win7 VC6.0 office2007
傻X 2013-02-05
  • 打赏
  • 举报
回复
以前搞过的一篇Word的内容 链接
jimette 2013-02-05
  • 打赏
  • 举报
回复
void CTestView::OnBatterylife() 
{
   COleDispatchDriver disp;
   COleException *e = new COleException;
   
   try {
      // Create instance of Microsoft System Information Control 
      // by using ProgID.
      if (disp.CreateDispatch("SYSINFO.Sysinfo.1", e))
      {
         //Call BatteryLifePercent.     
         short nBatteryLifePercent;
         
         disp.InvokeHelper(0x03, DISPATCH_PROPERTYGET, VT_I2, 
            (void*)&nBatteryLifePercent, NULL);            

         if (nBatteryLifePercent == 255)
            AfxMessageBox("Battery Life % unknown");            
         else
         {
            CString cStr;
            cStr.Format("Battery Life is at %d%%",
                nBatteryLifePercent);
            AfxMessageBox(cStr);
         }
      }
      else
         throw e;

   }
   
   //Catch control-specific exceptions.
    catch (COleDispatchException * e) 
   {
      CString cStr;

      if (!e->m_strSource.IsEmpty())
         cStr = e->m_strSource + " - ";
      if (!e->m_strDescription.IsEmpty())
         cStr += e->m_strDescription;
      else
         cStr += "unknown error";

      AfxMessageBox(cStr, MB_OK, 
         (e->m_strHelpFile.IsEmpty())? 0:e->m_dwHelpContext);

      e->Delete();
   }
   //Catch all MFC exceptions, including COleExceptions.
   // OS exceptions will not be caught.
    catch (CException *e) 
   {
      TRACE("%s(%d): OLE Execption caught: SCODE = %x", 
         __FILE__, __LINE__, COleException::Process(e));
      e->Delete();
   }
}
源代码 void CExcelTestDlg::OnExceltest() { // TODO: Add your control notification handler code here _Application ExcelApp; Workbooks wbsMyBooks; _Workbook wbMyBook; Worksheets wssMysheets; _Worksheet wsMysheet; Range rgMyRge; //创建Excel 服务器(启动Excel) if (!ExcelApp.CreateDispatch("Excel.Application",NULL)) { AfxMessageBox("创建Excel服务失败!"); exit(1); } //利用模板文件建立新文档 wbsMyBooks.AttachDispatch(ExcelApp.GetWorkbooks(),true); wbMyBook.AttachDispatch(wbsMyBooks.Add(_variant_t("g:\\exceltest\\MyTemplate.xlt"))); //得到worksheets wssMysheets.AttachDispatch(wbMyBook.GetWorksheets(),true); //得到sheet1 wsMysheet.AttachDispatch(wssMysheets.GetItem(_variant_t("sheet1")),true); //得到全部的cells,此时,rgMyRge是cells的集合 rgMyRge.AttachDispatch(wsMysheet.GetCells(),true); //设置一行一列的单元的值 rgMyRge.SetItem(_variant_t((long)1),_variant_t((long)1),_variant_t("This is a Excel Test Program!")); //得到所有的列 rgMyRge.AttachDispatch(wsMysheet.GetColumns(),true); //设置第一列 rgMyRge.AttachDispatch(rgMyRge.GetItem(_variant_t((long)1),vtMissing).pdispVal,true); //设置列宽 rgMyRge.SetColumnWidth(_variant_t((long)200)); //调用模版预先存放的宏 ExcelApp.Run(_variant_t("CopyRow"),_variant_t((long)10),vtMissing,vtMissing, vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing, vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing, vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing, vtMissing,vtMissing,vtMissing,vtMissing,vtMissing,vtMissing); //打印浏览 wbMyBook.SetSaved(true); ExcelApp.SetVisible(true); wbMyBook.PrintPreview(_variant_t(false)); //释放内存 rgMyRge.ReleaseDispatch(); wsMysheet.ReleaseDispatch(); wssMysheets.ReleaseDispatch(); wbMyBook.ReleaseDispatch(); wbsMyBooks.ReleaseDispatch(); ExcelApp.ReleaseDispatch(); } MFC调用excel
本资源包含两部分,第一部分是WPS OFFICE 2012二次开发FAQ,目录如下,内含部分VC和VB的源码指导,第二部分是WPS Office二次开发帮助文档,详细描述了wps,et,wpp的对象、属性和方法等接口,值得你拥有 1 二次开发的兼容性FAQ.....................................................................................................................3 1.1 WPS Office 2012 的二次开发开发和微软的Office 二次开发有什么异同..........................3 1.1.1 模块对象的区别........................................................................................................... 3 1.1.2 枚举常量的区别........................................................................................................... 3 1.1.3 commandbars 调用的区别............................................................................................. 3 1.2 WPS Office2012 的接口类对象和对应的DLL 文件.............................................................4 1.3 原有的与WPS Office 2003(WPS2003)、WPS Office 2002(WPS2002)、WPS Office2005 (WPS2005)、WPS Office 2007(2007)、WPS Office 2009(2009)结合的第三方程序,可 以直接和WPS Office2012 结合运行吗?.................................................................................... 4 1.4 原有的与WPS Office 2003 或者WPS Office 2002 结合的第三方程序,需要做什么改动 才能正常和WPS Office2012 结合运行?.................................................................................... 4 1.5 调用WPS 接口API 方法时要注意Variant 参数类型的传递。.......................................... 5 1.6 通过注册表修改宏代码的安全级别。.................................................................................. 5 2 二次开发文字部分FAQ.....................................................................................................................6 2.1 如何启动WPS 文字模块?....................................................................................................6 2.2 如何退出WPS 文字模块?....................................................................................................6 2.3 如何得到WPS 中的工具栏数?............................................................................................6 2.4 如何隐藏工具栏?..................................................................................................................6 2.5 如何使工具栏的按钮失效?.................................................................................................. 7 2.6 如何获得一个文档?..............................................................................................................7 2.7 如何打开wps 文档?............................................................................................................. 7 2.8 如何关闭一个文档?..............................................................................................................7 2.9 如何保存一个文档?..............................................................................................................7 2.10 如何获得或修改当前用户名?............................................................................................7 2.11 如何在当前文档中添加一个表格?.................................................................................... 8 2.12 如何获取表格的行和列?....................................................................................................8 2.13 如何选中一个表?................................................................................................................8 2.14 如何修改一个表格的某个单元格的内容?........................................................................8 2.15 .如何设置一个表格的单元格的高度和宽度?....................................................................8 2.16 表格增加一行之后,要获取增加表格的内容,必须重新给表格变量赋值.................... 9 2.17 如何添加一个书签?............................................................................................................9 2.18 如何替换一个书签的内容?..............................................................................................10 2.19 如何获取和设置默认打印机?..........................................................................................10 2.20 如何打印一篇已打开的文档?..........................................................................................10 2.21 如何获取和设置某些文字的字体属性?..........................................................................10 2.22 如何获取和设置段落的格式?.......................................................................................... 11 2 2.23 如何通过注册表获取WPS 安装版本及安装路径?........................................................11 2.24 如何在插入对象里添加WPS 文档对象?.......................................................................12 2.25 在WPS 文字中使用Find 的用法...................................................................................... 12 2.26 去掉Find 替换后出现的对话框........................................................................................ 12 2.27 如何通过MIME 设置实现WPS 文字嵌入浏览器的方式打开服务器DOC 或WPS 文档 ...................................................................................................................................................... 12 2.28 如何在不破坏书签的情况下设置内容?..........................................................................13 2.29 为什么在使用Range.Text 为文档、书签,或用FormField.Result 为窗体域设置文本内 容时,回车符不见了?............................................................................................................... 13 2.30 如何判断文档的设计模式状态,如何退出设计模式?.................................................. 13 2.31 如何隐藏表格的智能扩展标记?......................................................................................13 2.32 如何通过API 实现不显示表格虚线?............................................................................. 14 3 二次开发电子表格部分FAQ...........................................................................................................14 3.1 如何启动WPS 电子表格模块?..........................................................................................14 3.2 如何退出电子表格?............................................................................................................14 3.3 如何打开一个电子表格文档?............................................................................................ 14 3.4 如何关闭一个电子表格文档?............................................................................................ 15 3.5 如何保存一个电子表格文档?............................................................................................ 15 3.6 如何设置一个单元格的大小?............................................................................................ 15 3.7 如何获取单元格中的内容?................................................................................................ 15 3.8 如何设置单元格中的内容?................................................................................................ 15 3.9 如何设置单元格中的公式?................................................................................................ 16 3.10 如何设置单元格的边框?..................................................................................................16 3.11 如何读取批注的内容.......................................................................................................... 16 3.12 如何添加批注?..................................................................................................................16 3.13 如何设置单元格内字体的属性?......................................................................................17 3.14 如何打印电子表格文档?.................................................................................................... 17 3.15 如何在插入对象里添加WPS 表格对象?.........................................................................17 3.16 WPS 表格中如何在默认位置插入图片..............................................................................18 3.17 WPS 表格中如何插入图表................................................................................................. 18 3.18 通过MIME 设置WPS 表格嵌入浏览器方式打开服务器的et 或xls 文档....................18

16,472

社区成员

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

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

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