作成とExcelファイルへの追加を自動化できるように、C#でExcelをいじり始めました。
ファイルを開いてそのデータを更新し、既存のワークシートを移動できます。私の問題は、新しいシートを追加する方法です。
私は試した:
Excel.Worksheet newWorksheet;
newWorksheet = (Excel.Worksheet)excelApp.ThisWorkbook.Worksheets.Add(
Type.Missing, Type.Missing, Type.Missing, Type.Missing);
しかし、私は以下になりますCOM Exceptionと私のグーグルは私に答えを与えていません。
HRESULTからの例外:0x800A03ECソース: "Interop.Excel"
誰かが私の悲惨さから私を追い出すことができるかもしれないと思っています。
素晴らしい返信をありがとうございます。 @AR。、あなたの星、それは完璧に動作します。昨夜、Excel.exe
は閉じていませんでした。そのため、私はいくつかの調査を行い、COMオブジェクトをリリースする方法を見つけました。最終的なコードは次のとおりです。
using System;
using System.Collections.Generic;
using System.Text;
using System.Reflection;
using System.IO;
using Excel;
namespace testExcelconsoleApp
{
class Program
{
private String fileLoc = @"C:\temp\test.xls";
static void Main(string[] args)
{
Program p = new Program();
p.createExcel();
}
private void createExcel()
{
Excel.Application excelApp = null;
Excel.Workbook workbook = null;
Excel.Sheets sheets = null;
Excel.Worksheet newSheet = null;
try
{
FileInfo file = new FileInfo(fileLoc);
if (file.Exists)
{
excelApp = new Excel.Application();
workbook = excelApp.Workbooks.Open(fileLoc, 0, false, 5, "", "",
false, XlPlatform.xlWindows, "",
true, false, 0, true, false, false);
sheets = workbook.Sheets;
//check columns exist
foreach (Excel.Worksheet sheet in sheets)
{
Console.WriteLine(sheet.Name);
sheet.Select(Type.Missing);
System.Runtime.InteropServices.Marshal.ReleaseComObject(sheet);
}
newSheet = (Worksheet)sheets.Add(sheets[1], Type.Missing, Type.Missing, Type.Missing);
newSheet.Name = "My New Sheet";
newSheet.Cells[1, 1] = "BOO!";
workbook.Save();
workbook.Close(null, null, null);
excelApp.Quit();
}
}
finally
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(newSheet);
System.Runtime.InteropServices.Marshal.ReleaseComObject(sheets);
System.Runtime.InteropServices.Marshal.ReleaseComObject(workbook);
System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);
newSheet = null;
sheets = null;
workbook = null;
excelApp = null;
GC.Collect();
}
}
}
}
すべてのご協力ありがとうございます。
ARの別の「Up Tick」...ですが、相互運用性を使用する必要がない場合は、完全に回避します。この製品は実際には非常に興味深いものです: http://www.clearoffice.com/ そして、Excelファイルを操作するための非常に直感的で完全に管理されたAPIを提供しますそして無料のようです。 (少なくとも当面) SpreadSheetGear も優れていますが、高価です。
私の2セント。
Referenceを
Microsoft Excel 12.0/11.0 object Library
using Excel = Microsoft.Office.Interop.Excel;
// Include this Namespace
Microsoft.Office.Interop.Excel.Application xlApp = null;
Excel.Workbook xlWorkbook = null;
Excel.Sheets xlSheets = null;
Excel.Worksheet xlNewSheet = null;
string worksheetName ="Sheet_Name";
object readOnly1 = false;
object isVisible = true;
object missing = System.Reflection.Missing.Value;
try
{
xlApp = new Microsoft.Office.Interop.Excel.Application();
if (xlApp == null)
return;
// Uncomment the line below if you want to see what's happening in Excel
// xlApp.Visible = true;
xlWorkbook = xlApp.Workbooks.Open(@"C:\Book1.xls", missing, readOnly1, missing, missing, missing, missing, missing, missing, missing, missing, isVisible, missing, missing, missing);
xlSheets = (Excel.Sheets)xlWorkbook.Sheets;
// The first argument below inserts the new worksheet as the first one
xlNewSheet = (Excel.Worksheet)xlSheets.Add(xlSheets[1], Type.Missing, Type.Missing, Type.Missing);
xlNewSheet.Name = worksheetName;
xlWorkbook.Save();
xlWorkbook.Close(Type.Missing, Type.Missing, Type.Missing);
xlApp.Quit();
}
finally
{
System.Runtime.InteropServices.Marshal.ReleaseComObject(xlNewSheet);
System.Runtime.InteropServices.Marshal.ReleaseComObject(xlSheets);
System.Runtime.InteropServices.Marshal.ReleaseComObject(xlWorkbook);
System.Runtime.InteropServices.Marshal.ReleaseComObject(xlApp);
//xlApp = null;
}
これは、ワークシートを追加するために使用したものです
Workbook workbook = null;
Worksheet worksheet = null;
workbook = app.Workbooks.Add(1);
workbook.Sheets.Add();
Worksheet additionalWorksheet = workbook.ActiveSheet;
VSTOでアプリケーションレベルのアドインと同様の問題が発生しました。新しいシートを追加すると、例外HRESULT:0x800A03ECが発生しました。
エラーコード0x800A03EC(または-2146827284)はNAME_NOT_FOUNDを意味します。言い換えると、何かを要求したのに、Excelがそれを見つけることができません。
Dominic Zukiewicz @ ExcelエラーHRESULT:セル名で範囲を取得しようとしているときに0x800A03EC
そして、ついにThisWorkbookが例外をトリガーしたことに気付きました。 ActiveWorkbookは問題ありませんでした。
Excel.Worksheet newSheetException = Globals.ThisAddIn.Application.ThisWorkbook.Worksheets.Add(Type.Missing, sheet, Type.Missing, Type.Missing);
Excel.Worksheet newSheetNoException = Globals.ThisAddIn.Application.ActiveWorkbook.Worksheets.Add(Type.Missing, sheet, Type.Missing, Type.Missing);
ここに、私が考え出したいくつかのことを示します。
同じオブジェクトの複数のインスタンスを同時に開くことはできません。たとえば、_xlsheet1
_という新しいExcelシートオブジェクトをインスタンス化する場合、別のExcelシートオブジェクトexxlsheet2
_を作成する前に、それを解放する必要があります。 COMがオブジェクトの追跡を失い、サーバーにゾンビプロセスを残すように見えます。
同じファイルに複数のユーザーがアクセスしている場合、_Excel.workbooks
_に関連付けられたopenメソッドを使用して閉じることも難しくなります。代わりにAddメソッドを使用します。ファイルをロックしなくても同じように機能します。例えば。 xlBook = xlBooks.Add("C:\location\XlTemplate.xls")
COMオブジェクトを解放した後、ガベージコレクションを別のブロックまたはメソッドに配置します。
OLEDBを使用して、Excelファイルを作成および操作できます。リンクとサンプルについては この質問 をご覧ください。
[〜#〜] com [〜#〜]は間違いなく良い方法ではありません。より具体的には、Web環境を扱っている場合は、手間がかかりません...
私は次のオープンソースプロジェクトを成功裏に使用しました:
OOXML形式のExcelPackage(Office 2007)
.XLS形式のNPOI(Office 2003)
次のブログ投稿をご覧ください。