C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.73174 の関連記事表示

<< 0 >>
■73174  Re[2]: C#でExcelファイルを開くときの例外処理
□投稿者/ Ex -(2014/08/26(Tue) 06:49:20)
    回答のあったcatchをつかってコードを組んだのですが、
    マクロ実行後にoBook2.Close(false);で、以下エラーが発生しました。

    原因がわかりません。
    ----------------------
    型 'System.NullReferenceException' のハンドルされていない例外が test.exe で発生しました

    追加情報: オブジェクト参照がオブジェクト インスタンスに設定されていません。
    ----------------------



    Excel.Application oExcel2 = new Excel.Application();
    //表示する
    oExcel2.Visible = true;
    Workbooks oBooks2 = oExcel2.Workbooks;


    //例外処理
    try
    {
    //Excelファイル開く
    oBooks2.Open(strMacroPath2);
    }
    catch (Exception ex)
    {
    //Sheetがなかった場合のエラー処理
    //Appを閉じる
    oExcel2.Quit();

    //Errorメッセージ
    MessageBox.Show("excelありません");

    //実行を終了
    System.Environment.Exit(0);
    }

    //例外処理
    try
    {
    //マクロ実行(Testというサブプロシージャを動かす)
    oExcel2.Run("ThisWorkbook.Main");
    }
    catch (Exception ex)
    {
    //Sheetがなかった場合のエラー処理
    //Appを閉じる
    oExcel2.Quit();

    //Errorメッセージ
    MessageBox.Show("マクロ動きません");

    //実行を終了
    System.Environment.Exit(0);
    }

    //終了処理(リソース解放)
    oBook2.Close(false);

    System.Runtime.InteropServices.Marshal.ReleaseComObject(oBook2);
    oBook2 = null;

    System.Runtime.InteropServices.Marshal.ReleaseComObject(oBooks2);
    oBooks2 = null;


    oExcel2.Quit();
    System.Runtime.InteropServices.Marshal.ReleaseComObject(oExcel2);
    oExcel2 = null;
記事No.73170 のレス /過去ログ122より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -