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

- システム
エンジニア - C#でExcelの表示や保存はできるのでしょうか。
- プロジェクト
マネージャー - はい、できます。事前準備としてまずは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を保存できます。
- システム
エンジニア - 新規のExcelが表示する際は「Open Excel」ボタンをクリック、保存する際にはButton2_Clickメソッドのみを変更するのですね。
- プロジェクト
マネージャー - C#でExcelの表示や保存をする際には、この記事を参考に実際にソースコードで指定してみましょう。
まとめ
いかがでしたでしょうか。C#でのExcelの表示や保存の方法について説明しました。ここでは新規作成する方法について紹介しましたが、既存のExcelを開いて操作することもできます。
ぜひご自身でC#のソースコードを書いて、理解を深めてください。
FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
株式会社オープンアップシステムはこんな会社です
秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
数多くのエンジニアが集まります。

-
スマホアプリから業務系システムまで
スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。
-
充実した研修制度
毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。
-
資格取得を応援
スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。
-
東証プライム上場企業グループ
オープンアップシステムは東証プライム上場「株式会社オープンアップグループ」のグループ企業です。
安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。
株式会社オープンアップシステムに興味を持った方へ
株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。
年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。


C#新着案件New Job
システム開発/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(新宿駅)システム開発/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(新宿駅)デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円神奈川県横浜市(桜木町駅)デバック、テスト項目の作成/神奈川県横浜市/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円神奈川県横浜市(桜木町駅)基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代前半の方活躍中/経験1年以上の方活躍中】/在宅勤務
月給29万~34万円東京都新宿区(西新宿駅)基幹システム開発導入/東京都新宿区/【WEB面談可/C#経験者/20代後半~40代の方活躍中/経験年数不問】/在宅勤務
月給41万~50万円東京都新宿区(西新宿駅)