ホームページ > バックエンド開発 > C++ > 配列を変更しない UDF を Excel アドインに実装するにはどうすればよいですか?

配列を変更しない UDF を Excel アドインに実装するにはどうすればよいですか?

Susan Sarandon
リリース: 2024-11-16 05:52:03
オリジナル
510 人が閲覧しました

How Can Non-Array Changing UDFs be Implemented in Excel Add-Ins?

Excel アドインでの配列非変更 UDF の実装

Excel アドインでは、セル値を変更する UDF は通常禁止されています。ただし、Windows タイマーと Application.OnTime タイマーを組み合わせて使用​​すると、この制限を回避できます。

Windows タイマーの制限

Windows タイマーはセルを実行している間は VBA コードを実行できません。編集中か、ダイアログが開いています。この制限により、UDF 内のセル プロパティを直接変更できなくなります。

解決策: Application.OnTime Timer

この制限を回避するには、UDF 内で Windows タイマーを使用して、 Application.OnTime タイマーをスケジュールします。 Application.OnTime タイマーは安全であり、セルが編集されておらず、ダイアログが開いていない場合にのみ起動されます。

UDF 実装

  1. 作成通常のモジュール: 次のコードを UDF ではなく通常の VBA モジュールに配置します。 module.
  2. UDF 実装 (AddTwoNumbers): AddTwoNumbers UDF 内で、通常どおり合計を計算します。計算後:

    • 呼び出し元のセル参照をコレクションにキャッシュします。
    • タイマー ルーチン AfterUDFRoutine1 を開始するように Windows タイマーを設定します。
  3. 初回タイマーのルーチン(AfterUDFRoutine1):

    • Windows タイマーを停止します。
    • AfterUDFRoutine2 の安全な Application.OnTime タイマーをスケジュールします。
  4. 2 番目のタイマー ルーチン(AfterUDFRoutine2):

    • セル値の変更、画面更新の無効化、計算モードの変更など、UDF で許可されていないタスクを実行します。

例使用法

Private Sub TestAddTwoNumbers()
    Dim Cell As Range

    Set Cell = Range("A1")

    ' Cache the reference in the UDF
    Cell.Formula = "=AddTwoNumbers(1, 2)"

    ' Trigger the timer routine
    Cell.Calculate
End Sub
ログイン後にコピー

計算時に、呼び出し元の隣のセルを現在の値に設定することにより、セルの数式が変更されて新しい値が反映されます。

以上が配列を変更しない UDF を Excel アドインに実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート