
教えて下さい。
C#でEXCELシートにデータを出力していますが、その際に以下のような記述をした場合、
EXCELファイルは作成されるものの、そのファイルをダブルクリックで開こうとすると、
EXCELの枠だけ表示され、中身のシートが表示されない現象となってしまいます。
それらしきオブジェクトはすべて開放しているつもりですが、その事象を解決できません。
どこがおかしいか教えて頂きたいと思います。
記述に過不足あればご指摘下さい。
尚、環境は、WindowsXP Office2000-EXCEL です。
《記述内容》
//////////////////////////////////
//ここからエクセルシートへの転記//
//////////////////////////////////
Excel.Application objExcel = null;
Excel.Workbooks objBooks = null;
Excel.Workbook objBook = null;
Excel.Worksheet sheet = null;
Excel.Range range1 = null;
Excel.Range range2 = null;
Excel.Range range3 = null;
//ExcelのCOMオブジェクトの生成
objExcel = new Excel.Application();
//Excelを表示する設定
//objExcel.Visible = isVisible;
//ワークブックの集合体取得
objBooks = objExcel.Workbooks;
//ブックの新規作成
objBook = objBooks.Add(Missing.Value);
//シートを取得
sheet = (Excel.Worksheet)objBook.Sheets.get_Item(1);
//Rangeを取得
range1 = (Excel.Range)sheet.Cells[1, 1];
range2 = (Excel.Range)sheet.Cells[1, 2];
//文字列を設定
//ヘッダ書き込み
range1.Value = "仕入先名";
range2.Value = "図面番号";
//エクセルシート側の行数カウント変数
int rcount = 2;
//データテーブル側の行数カウント変数
int tcount = 0;
for (tcount = 0; tcount < mst_cnt;tcount++ )
{
range1 = (Excel.Range)sheet.Cells[rcount, 1];
range2 = (Excel.Range)sheet.Cells[rcount, 2];
range1.Value = 仕入先名[tcount];
range2.Value = 図面番号[tcount];
rcount++;
}
//エクセルシート削除
DeleteFile(@"c:\\" + h_no + ".xls");
//エクセルシート生成
objBook.SaveAs(
"c:\\" + h_no + ".xls",
Missing.Value,
Missing.Value,
Missing.Value,
Missing.Value,
Missing.Value,
0,
Missing.Value,
Missing.Value,
Missing.Value,
Missing.Value
);
//COMオブジェクト解放
Marshal.ReleaseComObject(range1);
Marshal.ReleaseComObject(range2);
//COMオブジェクトの開放(必須)
Marshal.ReleaseComObject(objBook);
objBook = null;
Marshal.ReleaseComObject(sheet);
sheet = null;
Marshal.ReleaseComObject(objBooks);
objBooks = null;
//System.Runtime.InteropServices.Marshal.ReleaseComObject(objExcel);
objExcel.Quit();
Marshal.ReleaseComObject(objExcel);
objExcel = null;
//objExcel.Quit();
return;
}
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
>range1.Value = 仕入先名[tcount];
>range2.Value = 図面番号[tcount];
の部分がエラーになるので
range1.Value = tcount;
range2.Value = tcount;
に変更し、
>DeleteFile
を
System.IO.File.Delete
に変更して試してみましたが、こちらの環境 ( Windows XP、VS 2008、Excel 2000 ) では再現できませんでした。
どこか別の関数とかで Excel の開放ができていないとか?
タスクマネージャのプロセスタブを監視しながら動作させてみてはいかがでしょうか。
この回答への補足
ご回答ありがとうございます!
早速、教えて頂いた内容の通り記述してみましたが、結果は同じでした。
確かにタスクマネージャのプロセスは、EXCEL.EXEが残ったままです。
何か開放忘れでしょうか。。。
申し訳ありません。
もう少し教えて頂きたいと思います。
No.1
- 回答日時:
なんだか不可解な現象ですけど、出力したファイルを開こうとしたときに、ガベージコレクトされずにメモリ上に残っていた Excel がアクティブになると問題の現象が起きるようです。
xls に出力した後で、メモリ上に残っている Excel をタスクマネージャで強制的に終了させると、この現象は起きないと思います。
とりあえず、
>objExcel.Quit();
>Marshal.ReleaseComObject(objExcel);
>objExcel = null;
の後に
GC.Collect();
を入れてみてはいかがでしょうか。
この回答への補足
ご回答ありがとうございます!
ご指摘頂いたように記述したら正しく起動するようになりました。
但し、もう1点、上記の記述をした場合、プログラムが起動している
最中はどうしても正しく開きません。(今までと同じ現象)
起動している最中は、何か掴んでいるのでしょうか???
教えて頂ければ幸いです。
よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2022/03/28 14:52
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- Visual Basic(VBA) エクセルのマクロを使ってメールを送る方法について教えてください 2 2022/03/29 01:36
- Excel(エクセル) Excel VBAどこが間違ってますか? 4 2023/07/17 10:04
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2022/10/11 12:55
- Visual Basic(VBA) VBAコードを張り付け後のエクセルの進め方 2 2023/02/07 18:24
- Visual Basic(VBA) VBAでoutlook365が起動しません。 4 2022/08/25 13:31
- Visual Basic(VBA) Excelで下記のようにマクロを作ったところ、一回目は実行できたのですが、二回目以降「実行時エラー1 1 2022/03/25 08:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C# ref引数のnull判定
-
C言語 dequeue
-
構造体の各メンバにfor文からア...
-
「Aに対するBの割合」と「Aに対...
-
C言語で%を使わない余りの出し方
-
基本的ですが・・・
-
複数のアドレスを関数から取得...
-
ランダムアクセスができない
-
C言語の初心者です。これを実行...
-
9-3の時の内部処理・・・
-
高(1)男子 初めてC言語でコー...
-
C++言語で、どうこのコード続け...
-
C言語を実行すると-infが出てき...
-
外部変数について
-
pを実数の定数とする。xの二次...
-
fprintfで微小な数値を書き込む...
-
for文の条件式について
-
C言語(高校1年の内容)について
-
文字列を分解したいのですが・・・
-
C++に関する質問です
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
構造体のリスト削除
-
コールバック関数はnullになら...
-
InvokeMemberメソッドとは何を...
-
C# ref引数のnull判定
-
双方向リストのバブルソートに...
-
C#でのEXCEL出力に関して
-
プログラミング(C#)のエラーに...
-
if文でゼロとNULLを除外するた...
-
PLSQLについて
-
バブルソートを使って文字列を...
-
【C++】ストリームオブジェクト...
-
SQLのIN関数に関して
-
文字列の結合方法(SQL)
-
ばばぬきプログラムについて
-
今度はdoubly linked listの問...
-
API 録音 MCI
-
大学で出されたc言語の課題に...
-
C言語
-
isset — 変数が宣言されている...
-
Aの値からBの値を除するとは??
おすすめ情報