C#でのExcelの表示や保存の方法とは?起動と終了・シートやセルの操作・保存

- SE
- C#でExcelの表示や保存はできるのでしょうか。
- PM
- はい、できます。事前準備としてまずはExcelをインストールしておきましょう。
C#でのExcelの表示や保存の方法とは?
今回は、C#でのExcelの表示や保存の方法について説明します。ここでは、ソリューションの設定方法やExcelの起動・終了・保存方法について紹介します。また、シートやセルの操作方法についても紹介します。
C#でのExcelの表示や保存の方法に興味のある方はぜひご覧ください。
事前準備
ここでは、Microsoft.Office.Interop.Excelを使ってExcelを操作します。動作環境にExcelがインストールされていることが前提です。
まず、C#のWindows Formアプリケーションを新規作成し、参照を追加します。「参照の追加」で参照マネージャが表示されます。「COM」を選択し検索ボックスに「Excel」と入力します。
「Microsoft Excel *.* Object Library」にチェックを付けて「OK」ボタンをクリックしてください。
起動と終了
C#でExcelを起動・終了する方法を紹介します。実際のソースコードを見てみましょう。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 |
using System; using System.Drawing; using System.Windows.Forms; using Excel = Microsoft.Office.Interop.Excel; using System.Runtime.InteropServices; namespace WindowsFormsApp1 { public partial class Form1 : Form { Button button1, button2; Excel.Application excelApp; public Form1() { this.AutoSize = true; this.Load += Form1_Load; } private void Form1_Load(object sender, EventArgs e) { // 起動ボタン button1 = new Button(); button1.Location = new Point(10, 10); button1.Text = "Open Excel"; button1.AutoSize = true; button1.Click += Button1_Click; this.Controls.Add(button1); // 終了ボタン button2 = new Button(); button2.Location = new Point(100, 10); button2.Text = "Close Excel"; button2.AutoSize = true; button2.Click += Button2_Click; this.Controls.Add(button2); } private void Button1_Click(object sender, EventArgs e) { // Excel起動 excelApp = new Excel.Application(); // 非表示にする excelApp.Application.Visible = false; excelApp.Application.DisplayAlerts = false; // Bookを追加 excelApp.Application.Workbooks.Add(Type.Missing); // Excel表示 excelApp.Application.Visible = true; } private void Button2_Click(object sender, EventArgs e) { // Excel終了 if (excelApp != null) { excelApp.Quit(); } excelApp = null; } } } |
「Open Excel」ボタンをクリックすると、新規のExcelが表示されます。「Close Excel」ボタンをクリックすると、Excelが終了します。このようにC#では、Excelの起動や終了ができます。
シートやセルの操作
C#では、Excelのシートやセルの操作ができます。実際のソースコードを見てみましょう。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
using System; using System.Drawing; using System.Windows.Forms; using Excel = Microsoft.Office.Interop.Excel; using System.Runtime.InteropServices; namespace WindowsFormsApp1 { public partial class Form1 : Form { Button button1, button2; Excel.Application excelApp; Excel.Workbook wb; Excel.Worksheet ws; Excel.Range rng; public Form1() { this.AutoSize = true; this.Load += Form1_Load; } private void Form1_Load(object sender, EventArgs e) { // 起動ボタン button1 = new Button(); button1.Location = new Point(10, 10); button1.Text = "Open Excel"; button1.AutoSize = true; button1.Click += Button1_Click; this.Controls.Add(button1); // 終了ボタン button2 = new Button(); button2.Location = new Point(100, 10); button2.Text = "Close Excel"; button2.AutoSize = true; button2.Click += Button2_Click; this.Controls.Add(button2); } private void Button1_Click(object sender, EventArgs e) { // Excel起動 excelApp = new Excel.Application(); // 非表示にする excelApp.Application.Visible = false; excelApp.Application.DisplayAlerts = false; // Bookを追加 wb = excelApp.Application.Workbooks.Add(Type.Missing); // シート選択 ws = (Excel.Worksheet)excelApp.Worksheets[1]; // シート名変更 ws.Name = "sampleSheet"; // セルに値を入力 for (int i = 1; i < 5; i++) { rng = ws.Cells[i, 1]; rng.Value2 = i; } // Excel表示 excelApp.Application.Visible = true; } private void Button2_Click(object sender, EventArgs e) { // Excel終了 if (excelApp != null) { excelApp.Quit(); } rng = null; ws = null; wb = null; excelApp = null; } } } |
実行すると、シート名を変更したり、セルに値を入力したりできることが分かります。ここでは紹介していませんが、セルの背景色やフォント色、フォントなどを変更することもできます。このようにC#では、Excelのシートやセルの操作ができます。
保存
C#でExcelを保存する方法を紹介します。実際のソースコードを見てみましょう。ここでは、Button2_Clickメソッドのみを変更します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
private void Button2_Click(object sender, EventArgs e) { // Excel保存 wb.SaveAs(@"C:\test\test.xlsx"); // Excel終了 if (excelApp != null) { excelApp.Quit(); } rng = null; ws = null; wb = null; excelApp = null; } |
「Open Excel」でExcelを表示して、「Close Excel」をクリックするとExcelを保存して終了します。保存先については、SaveFileDialogを表示させて、ユーザに指定させるのも良いでしょう。このようにC#では、SaveAsメソッドでExcelを保存できます。
- SE
- 新規のExcelが表示する際は「Open Excel」ボタンをクリック、保存する際にはButton2_Clickメソッドのみを変更するのですね。
- PM
- C#でExcelの表示や保存をする際には、この記事を参考に実際にソースコードで指定してみましょう。
まとめ
いかがでしたでしょうか。C#でのExcelの表示や保存の方法について説明しました。ここでは新規作成する方法について紹介しましたが、既存のExcelを開いて操作することもできます。
ぜひご自身でC#のソースコードを書いて、理解を深めてください。