pembangunan bahagian belakang
Tutorial C#.Net
Bagaimana untuk menggunakan C# untuk mengautomasikan tugas dalam Microsoft Excel?
Bagaimana untuk menggunakan C# untuk mengautomasikan tugas dalam Microsoft Excel?
Use Microsoft.Office.Interop.Excel for full Excel control when Excel is installed; otherwise prefer EPPlus for fast, cross-platform, server-safe Excel I/O without Excel.

Use Microsoft.Office.Interop.Excel to open and edit workbooks
You can automate Excel from C# by referencing the COM interop library. This is the most direct way when you need full control — like formatting cells, inserting charts, or interacting with VBA objects. But it requires Excel to be installed on the machine, and it’s not thread-safe.
Key points:
- Add reference to
Microsoft.Office.Interop.Excel(via COM tab in Visual Studio’s “Add Reference” dialog) - Always release COM objects explicitly using
Marshal.ReleaseComObject()— otherwise Excel.exe stays alive in background - Prefer early binding: declare types like
Application,Workbook,Worksheetinstead ofobject - Set
app.Visible = falseunless you need UI feedback during automation
using Excel = Microsoft.Office.Interop.Excel; using System.Runtime.InteropServices; <p>var app = new Excel.Application(); var wb = app.Workbooks.Open(@"C:\data\report.xlsx"); var ws = wb.Sheets[1] as Excel.Worksheet;</p><p>ws.Cells[1, 1].Value = "Updated by C#"; wb.Save(); wb.Close(); Marshal.ReleaseComObject(ws); Marshal.ReleaseComObject(wb); app.Quit(); Marshal.ReleaseComObject(app);</p>
Prefer EPPlus for fast, server-safe Excel I/O without Excel installed
If your task is reading/writing cell data, formulas, or basic styling — and you don’t need macros, charts, or real-time interaction — skip Interop entirely. EPPlus is faster, lightweight, and runs on Linux/macOS/Windows without Office.
Important notes:
- Requires
NuGet package EPPlus(v6+ needs a license for commercial use; v5.8.7 is MIT-licensed and still widely used) - No support for VBA, pivot tables, or complex drawing objects
- Works only with
.xlsx— not legacy.xls - Memory usage is low: uses Open XML SDK under the hood, no Excel process spawned
using OfficeOpenXml;
<p>ExcelPackage.LicenseContext = LicenseContext.NonCommercial; // or Commercial if licensed
using var package = new ExcelPackage(new FileInfo(@"C:\data\output.xlsx"));
var ws = package.Workbook.Worksheets.Add("Data");
ws.Cells["A1"].Value = "Hello from EPPlus";
ws.Cells["A2"].Formula = "SUM(A1:A1)";
package.Save();</p>
Handle COMException and zombie Excel processes reliably
The biggest pain point with Interop isn’t syntax — it’s cleanup. If an exception occurs before releasing objects, Excel.exe hangs. Always wrap in try/finally, and null-check before releasing.
- Catch
COMExceptionspecifically — often thrown on missing sheets, invalid ranges, or Excel already busy - Never assume
ws.Cells[row, col]exists — check fornullor usews.Cells[row, col].Value2instead of.Valuefor safer type handling - Call
GC.Collect()andGC.WaitForPendingFinalizers()*after* allReleaseComObject()calls infinally - Use
Process.GetProcessesByName("EXCEL")in dev to detect leaks — but avoid killing processes in production
When to avoid automation entirely — and what to use instead
Not every Excel-related task needs automation. If you’re generating reports from databases, consider exporting CSV or using SqlClient + DataTable.WriteXml() + XSLT. If users just need to view filtered data, a web grid with export-to-Excel button (e.g., via EPPlus on ASP.NET Core) is simpler and more scalable.
Interop makes sense only when:
- You must preserve existing Excel templates with macros or complex formatting
- You’re building an internal tool where Excel is guaranteed present
- You need to trigger or debug VBA logic from C#
Otherwise, default to EPPlus, or even CSV + System.Text.Json for structured interchange — especially if Excel is just a delivery format, not a runtime dependency.
Atas ialah kandungan terperinci Bagaimana untuk menggunakan C# untuk mengautomasikan tugas dalam Microsoft Excel?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!
Alat AI Hot
Undress AI Tool
Gambar buka pakaian secara percuma
AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.
Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik
Stock Market GPT
Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak
Artikel Panas
Alat popular
Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma
SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan
Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa
Dreamweaver CS6
Alat pembangunan web visual
SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)
Topik panas
Bagaimana untuk mengesahkan alamat e-mel dalam C#? (Corak regex)
Mar 08, 2026 am 12:06 AM
Adalah disyorkan untuk menggunakan biasa rasmi ringan Microsoft ^[a-zA-Z0-9._% -] @[a-zA-Z0-9.-] \.[a-zA-Z]{2,}$ untuk pengesahan format e-mel asas, meliputi 99% daripada input sebenar; cara yang lebih dipercayai ialah menggunakan pembina MailAddress dan hanya menangkap FormatException, sambil mengesahkan rentetan null/kosong terlebih dahulu.
Bagaimana untuk menggunakan refleksi untuk mendapatkan nilai harta dalam C#? (GetType)
Mar 06, 2026 am 12:15 AM
GetProperty harus digunakan bersama dengan GetValue untuk mendapatkan nilai harta dan bukannya hanya memanggil GetType; adalah perlu untuk memberi perhatian kepada butiran seperti keterlihatan harta, perhubungan warisan dan pengindeks, dan disyorkan untuk cache PropertyInfo untuk meningkatkan prestasi.
Bagaimana untuk menggunakan sifat dengan get set dalam C#? (Encapsulation)
Mar 10, 2026 am 12:33 AM
get/set tidak hanya menambah kurungan, tetapi merangkum titik permulaan: medan eksplisit diperlukan, operasi yang memakan masa dielakkan, ArgumentException dilemparkan apabila pengesahan gagal, pengubah suai akses berbeza disokong, init terhad kepada senario permulaan dan atribut logik pada asasnya ialah kaedah. Perhatian khusus mesti diberikan kepada penyahpepijatan dan prestasi.
Bagaimana untuk memisahkan rentetan dengan pembatas dalam C#? (String.Split)
Mar 12, 2026 am 12:21 AM
Ya, String.Split mengembalikan rentetan kosong secara lalai, menyebabkan item kosong disebabkan oleh pembatas berterusan atau pertama dan terakhir; anda perlu menggunakan StringSplitOptions.RemoveEmptyEntries untuk menapis, atau menapis secara manual; char[] digunakan untuk pemisahan aksara tunggal, dan rentetan[] digunakan untuk pemisahan subrentetan; Span.Split boleh mengelakkan peruntukan; melepasi had atas nombor akan memotong keputusan.
Bagaimana untuk menulis ke fail teks dalam C#? (Contoh StreamWriter)
Mar 05, 2026 am 12:14 AM
Anda mesti menggunakan menggunakan untuk memastikan bahawa StreamWriter dikeluarkan dengan betul. Laluan perlu dibina dengan Path.Combine dan direktori mesti dibuat terlebih dahulu. File.WriteAllText atau File.AppendAllText lebih disukai untuk memudahkan operasi.
Bagaimana untuk menggunakan jenis nullable dalam C#? (Jenis rujukan boleh batal)
Mar 06, 2026 am 12:14 AM
Selepas mendayakan nullable, rentetan bermaksud bukan nol (ralat akan dilaporkan jika null diberikan atau dereference tidak dikesan), string? secara eksplisit membenarkan null; fail lama perlu #nullableenable secara eksplisit untuk berkuat kuasa; API luaran lalai kepada kemungkinan null.
Bagaimana untuk menyertai rentetan dengan pemisah dalam C#? (String.Join)
Mar 13, 2026 am 12:02 AM
String.Join direka khas untuk penyambungan rentetan. Ia selamat, cekap dan sangat mudah dibaca. Hanya masukkan pembatas dan tatasusunan rentetan, dan elemen nol akan dilangkau secara automatik. Tatasusunan kosong atau null akan mengembalikan rentetan kosong. Pemformatan eksplisit diperlukan untuk mengendalikan jenis bukan rentetan. Dalam senario sensitif prestasi, tatasusunan diluluskan dahulu dan bukannya IEnumerable. StringBuilder sesuai untuk logik yang kompleks.
Bagaimana untuk mengukur masa pelaksanaan dalam C#? (Kelas jam randik)
Mar 16, 2026 am 12:13 AM
Jam randik.Start() perlu dipanggil untuk kejadian yang tidak dimulakan, jika tidak InvalidOperationException akan dilemparkan; StartNew() ialah kaedah statik yang boleh dibuat dan dimulakan dalam satu langkah, menjadikannya lebih selamat dan lebih biasa digunakan.





