自动化加载宏加载时,excel 无法正常工作

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 284876
症状
Microsoft Excel 加载自动化加载项在单元格时编辑 Excel 失败模式。仅在使用自动化加载项已请求加载到 Excel 时出现此问题。
原因
外接程序加载如果加载项将显示一个窗体或对话框框时,或如果该加载项对 Excel 试图更改 Excel 的状态进行自动请求,可能会出现此问题。下面的列表包括可能导致失败的自动化外接程序加载过程中的单元格编辑模式时被调用时 Excel 的自动化请求的示例:
  • 以编程方式更改当前所选内容。例如:
    Application.ActiveSheet.Range("A1").Select					
  • 在 Windows 中调用属性或方法的项的集合。例如:
    Application.ActiveWindow.Zoom = 200					
  • 更改一个 Excel 设置,如计算模式。有关示例:
    Application.CalculationMode = xlManual					
所有这些项目的代码试图更改 Excel 环境、 一个的工作簿或工作表的示例 ; 在编辑模式下不允许使用这些类型的操作。
解决方案
不要尝试在您的外接程序加载时上面提到的操作。add-在装载过程中调用的方法中包含 初始化 方法,如果您自动化加载项实现 IDTExtensibility2 接口、 OnConnection 和也 OnStartupComplete 方法。
状态
Microsoft 已经确认这是在 Microsoft 中的错误在本文开头列出的产品。
更多信息

重现问题的步骤

  1. 在 Visual Basic 中启动一个新的 ActiveX DLL 项目。
  2. 项目 菜单中单击 Project1 属性。要 TestAddIn,更改 项目名称,然后单击 确定
  3. 将下面的代码添加到代码模块中,为 Class1:
    Private Sub Class_Initialize()    MsgBox "Class_Initialize"End Sub					
  4. 生成 TestAddIn.dll。
  5. 在 Excel,启动一个新的工作簿。
  6. Microsoft Office Excel 2003 中或在 Microsoft Excel 2002 中,请按照下列步骤操作:
    1. 工具 菜单上指向 加载宏,然后单击 自动
    2. 在列表中单击 TestAddIn.Class1,然后单击 确定
    3. 加载宏 对话框中单击 确定
    在 Microsoft Office Excel 2007 年,请按照下列步骤操作:
    1. 单击 Microsoft Office 按钮,然后单击 Excel 选项
    2. 单击 加载 项选项卡。
    3. 管理 列表中单击 Excel 加载宏,然后单击 定位
    4. 单击 加载宏 对话框中的 自动化
    5. 在列表中单击 TestAddin.Class1,然后单击 确定
    6. 单击 确定
  7. 类型 = 一个 中的任意单元格。带有文本"Class_Initialize"消息框出现。
  8. 单击 确定 以关闭消息框。在少数的秒后 Excel 将会失败。
参考
有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
291392信息: Excel COM 外接程序和自动化的加载宏
com 外接程序加载项 xp 关闭退出 xl2002 xl2003 XL2007

警告:本文已自动翻译

属性

文章 ID:284876 - 上次审阅时间:02/09/2007 20:00:40 - 修订版本: 4.2

Microsoft Office Excel 2007, Microsoft Office Excel 2003, Microsoft Excel 2002 标准版

  • kbmt kbautomation kbbug kbpending KB284876 KbMtzh
反馈