Bỏ qua để tới nội dung chính
Đăng nhập với Microsoft
Đăng nhập hoặc tạo một tài khoản.
Xin chào,
Chọn một tài khoản khác.
Bạn có nhiều tài khoản
Chọn tài khoản bạn muốn đăng nhập.
Tiếng Anh
Chúng tôi rất tiếc. Bài viết này không có bằng ngôn ngữ của bạn.

Symptoms

When Microsoft Excel loads an Automation add-in during cell edit mode, Excel fails. This problem only occurs with Automation add-ins that have been Demand Loaded into Excel.

Cause

This problem can occur when an add-in loads if the add-in displays a form or dialog box, or if the add-in makes an Automation request to Excel that tries to change the state of Excel. The following list includes samples of Automation requests that may cause Excel to fail when it is called while an Automation add-in loads during cell edit mode:

  • Programmatically change the current selection. For example:

    Application.ActiveSheet.Range("A1").Select
  • Call a property or method of an item in the Windows collection. For example:

    Application.ActiveWindow.Zoom = 200
  • Change an Excel setting such as the calculation mode. For example:

    Application.CalculationMode = xlManual

All of these items are examples of code attempts to change the Excel environment, a workbook, or a worksheet; these types of actions are not permitted while in edit mode.

Resolution

Do not try the above-mentioned actions while your add-in loads. Add-in methods that are called during the load include the Initialize method and, if your Automation add-in implements the IDTExtensibility2 interface, the OnConnection and OnStartupComplete methods as well.

Status

Microsoft has confirmed that this is a bug in the Microsoft products that are listed at the beginning of this article.

More Information

Steps to Reproduce Problem

  1. Start a new ActiveX DLL project in Visual Basic.

  2. From the Project menu, click Project1 Properties. Change the Project Name to TestAddIn, and then click OK.

  3. Add the following code to the code module for Class1:

    Private Sub Class_Initialize()
    MsgBox "Class_Initialize"
    End Sub
  4. Build TestAddIn.dll.

  5. In Excel, start a new workbook.

  6. In Microsoft Office Excel 2003 or in Microsoft Excel 2002, follow these steps:

    1. On the Tools menu, point to Add-Ins, and then click Automation.

    2. In the list, click TestAddIn.Class1, and then click OK.

    3. In the Add-Ins dialog box, click OK.

    In Microsoft Office Excel 2007, follow these steps:

    1. Click the Microsoft Office Button, and then click
      Excel Options.

    2. Click the Add-Ins tab.

    3. In the Manage list, click Excel Add-ins, and then click Go.

    4. In the Add-Ins dialog box, click
      Automation.

    5. In the list, click TestAddin.Class1, and then click OK.

    6. Click OK.

  7. Type =a in any cell. A message box with the text "Class_Initialize" appears.

  8. Click OK to dismiss the message box. After a few seconds, Excel fails.

References

For additional information, click the following article number to view the article in the Microsoft Knowledge Base:

291392 INFO: Excel COM Add-ins and Automation Add-ins

Bạn cần thêm trợ giúp?

Bạn muốn xem các tùy chọn khác?

Explore subscription benefits, browse training courses, learn how to secure your device, and more.

Communities help you ask and answer questions, give feedback, and hear from experts with rich knowledge.

Thông tin này có hữu ích không?

Điều gì ảnh hưởng đến trải nghiệm của bạn?
Khi nhấn gửi, phản hồi của bạn sẽ được sử dụng để cải thiện các sản phẩm và dịch vụ của Microsoft. Người quản trị CNTT của bạn sẽ có thể thu thập dữ liệu này. Điều khoản về quyền riêng tư.

Cảm ơn phản hồi của bạn!

×