
たびたびお世話になります。
結構大きなフォームを作成して、ようやく開発が終了したのですが、ある時を境に急にフォームを表示しようとすると実行時エラーになります。
Microsoft Visual Basic
-------------------------------------------------------------
実行時エラー'-2147417848 (80010108)':
'Value' メソッドは失敗しました 'IMdcOptionButton'オブジェクト
このあと、ご迷惑をおかけします、現象を Microsoft に報告しますというメッセージが出ます。
いつもメッセージは一緒です。
不思議なことに、Excel を起動し、Alt+11 で VBE を起動し、フォームを開発用に開き、再生ボタンをクリックしてフォームを表示させると、無事表示されます。
一度無事に表示されると、いつもやっているようにマクロから Show で表示しても表示されます。
これも必ず再現されます。
どうすれば回避できるでしょうか。
何かわかればよろしくお願いします。
OS は Windows XP SP2、
Office は 2007 (12.0.6331,5000) SP1 MSO (12.0.6333.5000) です。
ここまで苦労して開発してテストして、さっき顧客にできたからいまから送ると言ったのに泣きそうです :-(
No.1ベストアンサー
- 回答日時:
こんにちは。
原因不明なエラーで悩んだときの最初のチェック項目は、「参照設定」
です。参照不可項目があるとき、無関係にみえる場所でもエラーが
発生しますので。
次に、根拠の薄い話。
まずは、確認済み事項から。
えーと、Office の VBA プロジェクトはコンパイルを重ねると序々に
ファイルのサイズが肥大化します。例えば、モジュール内のプロシー
シャを全て削除しても、逆にファイルサイズが増える場合があるという
ことです。
# 確か、確認したのは Win98SE + Excel2002 環境だったかな
ここからは、推測(私見)。
プロシージャを減らしたのに、ファイルサイズが肥大化するということ
は、修正にともなう何らかの残骸が残る、例えば、コンパイル時に消去
されるべきものが消去されず、蓄積されていくというイメージですよね。
この現象については資料が見つからず、確かなことが私にはわかり
ませんが、VBA プロジェクトの動作に何らかの悪影響を与える可能性は
あるわけです。
したがって、私はある一定の作業量を超えたら、モジュールをエクス
ポートし、再インポートのリフレッシュ作業を行います。
# つまり、コンパイラに問題があるのではないかと
# ちなみに、VBA は純粋なインタプリタ言語ではありません
# Pコードという中間言語にコンパイルされて実行されます
以上が私の私見&経験則。
# この話は数年前の経験に基づき書いてます。現在では
# フィックスされていてのかもしれません。
長々書きましたが、次点のアドバイスとして再インポート^^;
ありがとうございます!
「参照」はややこしいので使っていませんでした (^^)
全エクスポート、新規ブック作成、再インポートでバッチリでした。
エラー番号でググったところ、過去に別のエクセルの別のウィジェットで同じ現象になって MS がフィックスしたそうです。
よってこの現象もそのうち対策されるでしょう。
ありがとうございました!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
End Sub が必要です。
-
VB.NETのStructureの使い方を教...
-
フォートランのエラーについて...
-
intel fortranのエラーで困って...
-
43:syntax error at end of input
-
Excel VABについて 下記記述が...
-
フォートラン(fortran)のエラー...
-
教えて下さい
-
特定のPCだけ動作しないVBAマク...
-
UserForm1.Showでエラーになり...
-
【エクセル】測定時間がバラバ...
-
配列数式の解除
-
メッセージボックスのOKボタ...
-
【VBA】ワークブックを開く時に...
-
String""から型'Double'への変...
-
wordを起動した際に特定のペー...
-
一つのTeratermのマクロで複数...
-
エクセルに張り付けた写真のフ...
-
TERA TERMを隠す方法
-
エクセルで縦に並んだデータを...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
End Sub が必要です。
-
フォートランのエラーについて...
-
VBでエラー'ActiveX component ...
-
他クラスからForm1内コントロル...
-
対応する関数ヘッダーがありません
-
intel fortranのエラーで困って...
-
フォートラン(fortran)のエラー...
-
クラスに volatile は必要?
-
Excel VABについて 下記記述が...
-
Delphiでif文がうまく書けないです
-
ラズパイ上の、pythonのエラー...
-
Excel VBA: UserForm.Show で実...
-
コンパイルエラー
-
ISLispのsetq関数について教え...
-
C# IEnumerable が IEnumerable...
-
typedef による2重定義
-
構造体のポインタ参照
-
C2065: 'EnumDisplayDevices' :...
-
STL mapでアクセス違反
-
43:syntax error at end of input
おすすめ情報