Accessで使えるAPI
Access便利ツール
Accessの小技
Accessの常識・バグ情報
  Run command
過去のVBA道具箱

Vitamin Excel
窓の影(Windows情報)

Excel銀行振込データ作成
(V2.30 UPD 07/11/11)

Excel最適化
(V1.07 UPD 05/11/06)

銀行カレンダー関数のExcelアドイン
(V1.10 UPD 07/03/02)

MdbCmpt(V2.05)
MDB最適化&バックアップ
(UPD 01/03/03)


自己解凍ファイル作成
(UPD 02/06/17)

kotonoha(UPD 05/06/26)

 no_smoke.gif (3476 バイト)
禁煙日記UPD(00/02/19)

(更新終了しました)

お気に入り UPD 06/02/03)



(有)ロードシステム

911-0843  福井県
勝山市鹿谷町本郷15-9
info@loadsystem.net
Last Update:08/01/27
(Since 99/02/20)
 Copyright(C)
Loadsystem Inc.
1999-2007


【広告】


   Excel VBAに効く Vitamin E
シート上のコントロールのオブジェクト名は変えるな[97]
Excel97でシート上に貼り付けたコマンドボタン等のオブジェクト名を変更した場合、そのシートをコピーしてもオブジェクト名は移行されません。(02/01/11MS確認)
プログラムの可読性を高めるために、次のようにオブジェクト名を変更する場合があります。
  CommandButton1 → cmdStart
このSheetをコピーしますとコピー先のコマンドボタンのオブジェクト名は  CommandButton1
に変わってしまいます。当然このコマンドボタンをクリックしてもマクロは実行されません。 Sub cmdStart_click() は(General)セクションに移動しています。
ちなみにUserFormをコピーしてもこのような現象は発生しません。
MSではこの現象を認めた上で、シートのコマンドとUserFormのコマンドはぜんぜん別物なのでこれはExcelの仕様ですとのことでした。でも次のことを考慮すればバグといわれてもしかたないのでは?
  1.RangeとかShape オブジェクトにつけた名前は問題なく移行される。
    (RangeとかShape オブジェクトの名前はオブジェクト名でないと逃げるでしょうが・・・)
  2.Excel 2000ではこの現象が発生しない。
    (やっぱり直したんだ)
おまけ情報: Excelをコンパイルすると実行速度が上がるか
MSではほとんど変わらないといっています。でも文法チェックの意味しかないのかというとそうでもなく、できるだけコンパイル済みの状態で実行して欲しいとのことでした。(02/01/09MS確認)
CmdOnSheet.xlsのダウンロード(CmdOnSheet.LZH)

(UPD:02/01/12)