C#でExcelに書き込む [Interopを使用しない] コード例チュートリアル

This article was translated from English: Does it need improvement?
Translated
View the article in English

によって イライジャ・ウィリアムズ

C#を使用してExcelファイルを作成、開く、および保存する方法のステップバイステップの例に従い、合計、平均、カウントなどの基本的な操作を適用します。 IronXL.Excelは、さまざまなスプレッドシート形式を読み取るためのスタンドアロンの.NETソフトウェアライブラリです。 必要ありませんマイクロソフトエクセルインストールする必要はなく、またInteropに依存することもありません。


概要

IronXLを使用して、Excelファイルを開いて書き込みます。

エクセルファイルを開く、書き込む、保存する、そしてカスタマイズするには、使いやすい IronXL C#ライブラリ。

ダウンロード a GitHubからのサンプルプロジェクト またはご自身のものを使用し、チュートリアルに従ってください。

  1. IronXL Excel ライブラリをインストールするには NuGet DLLのダウンロード用

  2. WorkBook.Loadメソッドを使用して、任意のXLS、XLSX、またはCSVドキュメントを読み込みます。

  3. 直感的な構文を使用してセルの値を取得する: シート [「A11」].DecimalValue

    このチュートリアルでは、次の手順を説明します:

    • IronXL.Excelのインストール:既存のプロジェクトにIronXL.Excelをインストールする方法。
    • 基本操作: Excelでブックを作成または開くときの基本操作手順、シートの選択、セルの選択、ブックの保存
    • 高度なシート操作:ヘッダーまたはフッターの追加や数学的操作ファイル、その他の機能のようなさまざまな操作機能を活用する方法。

      Excelファイルを開く : クイックコード

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-1.cs
using IronXL;

WorkBook workBook = WorkBook.Load("test.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
IronXL.Range range = workSheet["A2:A8"];
decimal total = 0;

// iterate over range of cells
foreach (var cell in range)
{
    Console.WriteLine("Cell {0} has value '{1}'", cell.RowIndex, cell.Value);
    if (cell.IsNumeric)
    {
        // Get decimal value to avoid floating numbers precision issue
        total += cell.DecimalValue;
    }
}

// Check formula evaluation
if (workSheet["A11"].DecimalValue == total)
{
    Console.WriteLine("Basic Test Passed");
}
Imports IronXL

Private workBook As WorkBook = WorkBook.Load("test.xlsx")
Private workSheet As WorkSheet = workBook.DefaultWorkSheet
Private range As IronXL.Range = workSheet("A2:A8")
Private total As Decimal = 0

' iterate over range of cells
For Each cell In range
	Console.WriteLine("Cell {0} has value '{1}'", cell.RowIndex, cell.Value)
	If cell.IsNumeric Then
		' Get decimal value to avoid floating numbers precision issue
		total += cell.DecimalValue
	End If
Next cell

' Check formula evaluation
If workSheet("A11").DecimalValue = total Then
	Console.WriteLine("Basic Test Passed")
End If
VB   C#

Excelファイルに変更を書き込み保存:クイックコード

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-2.cs
workSheet["B1"].Value = 11.54;

// Save Changes
workBook.SaveAs("test.xlsx");
workSheet("B1").Value = 11.54

' Save Changes
workBook.SaveAs("test.xlsx")
VB   C#

ステップ 1

IronXL C#ライブラリを無料でインストール

今日から無料トライアルでIronXLをあなたのプロジェクトで使い始めましょう。

最初のステップ:
green arrow pointer


IronXL.Excelは、.NETでExcelファイルを開き、読み取り、編集、保存するための柔軟かつ強力なライブラリを提供します。 それは、WindowsアプリケーションやASP.NET MVC、.NET Coreアプリケーションなど、すべての.NETプロジェクトタイプにインストールして使用できます。

NuGetを使用してExcelライブラリをVisual Studioプロジェクトにインストールする

最初のステップはIronXL.Excelをインストールすることです。 プロジェクトにIronXL.Excelライブラリを追加するには、2つの方法があります: NuGetパッケージマネージャーまたはNuGetパッケージマネージャーコンソール。

プロジェクトにIronXL.ExcelライブラリをNuGetを使用して追加するには、可視化されたインターフェースであるNuGetパッケージマネージャを使用して行うことができます。

  1. マウスを使用して -> プロジェクトの名前を右クリック -> 「NuGet パッケージの管理」を選択

    Select Manage Nuget Package related to NuGetを使用してExcelライブラリをVisual Studioプロジェクトにイ...

  2. 参照タブから -> IronXL.Excelを検索 -> インストール

    Search For Ironxl related to NuGetを使用してExcelライブラリをVisual Studioプロジェクトにインスト...

  3. 完了しました。

    And We Are Done related to NuGetを使用してExcelライブラリをVisual Studioプロジェクトにインストー...

NuGet パッケージ マネージャー コンソールを使用してインストール

  1. ツール -> NuGetパッケージマネージャー -> パッケージマネージャーコンソールから

    Package Manager Console related to NuGet パッケージ マネージャー コンソールを使用してインストール

  2. 実行コマンド -> Install-Package IronXL.Excel -Version 2019.5.2

    Install Package Ironxl related to NuGet パッケージ マネージャー コンソールを使用してインストール

DLLを使用して手動インストール

以下を手動でインストールすることもできます DLL (ディーエルエル) プロジェクトまたはグローバルアセンブリキャッシュに追加します。 もちろんです!翻訳したいコンテンツを提供してください。それに従って正確な日本語訳を提供いたします。

PM > Install-Package IronXL.Excel もちろんです!翻訳したいコンテンツを提供してください。それに従って正確な日本語訳を提供いたします。


チュートリアルの方法

基本操作: 作成、開く、保存

2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

HelloWorldプロジェクトを作成

.1.1. Visual Studioを開く

Open Visual Studio related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

.1.2. 新しいプロジェクトを作成を選択

Choose Create New Project related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

.1.3. コンソール アプリ (.NET フレームワーク) を選択

Choose Console App related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

サンプルに「HelloWorld」という名前を付けて、作成をクリックします。

Give Our Sample Name related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

.1.5. これでコンソールアプリケーションが作成されました

Console Application Created related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーシ...

.1.6. IronXL.Excel を追加 => インストールをクリック

Add Ironxl Click Install related to 2.1. サンプルプロジェクト: HelloWorld コンソールアプリケーション

.1.7. Excelファイルの最初のシートの最初のセルを読み込み、印刷するための最初の数行を追加します。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-3.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\HelloWorld.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
string cell = workSheet["A1"].StringValue;
Console.WriteLine(cell);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\HelloWorld.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim cell As String = workSheet("A1").StringValue
Console.WriteLine(cell)
VB   C#

2.2. 新しいExcelファイルを作成

IronXLを使用して新しいExcelファイルを作成する

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-4.cs
WorkBook workBook = WorkBook.Create(ExcelFileFormat.XLSX);
workBook.Metadata.Title = "IronXL New File";
WorkSheet workSheet = workBook.CreateWorkSheet("1stWorkSheet");
workSheet["A1"].Value = "Hello World";
workSheet["A2"].Style.BottomBorder.SetColor("#ff6600");
workSheet["A2"].Style.BottomBorder.Type = IronXL.Styles.BorderType.Dashed;
Dim workBook As WorkBook = WorkBook.Create(ExcelFileFormat.XLSX)
workBook.Metadata.Title = "IronXL New File"
Dim workSheet As WorkSheet = workBook.CreateWorkSheet("1stWorkSheet")
workSheet("A1").Value = "Hello World"
workSheet("A2").Style.BottomBorder.SetColor("#ff6600")
workSheet("A2").Style.BottomBorder.Type = IronXL.Styles.BorderType.Dashed
VB   C#

2.3. 辞書

辞書(dictionary)とは、一連のキー(key)とその対応するバリュー(value)を保持するデータ構造の一種です。辞書は、キーとバリューのペアを要素として扱い、これによりキーが一意に対応するバリューを迅速に検索、追加、削除することができます。Pythonでは辞書は非常に柔軟であり、多くの状況で効率的なデータ管理を提供します。

使用例:

# 辞書の作成
my_dict = {
    "キー1": "バリュー1",
    "キー2": "バリュー2",
    "キー3": "バリュー3",
}

# バリューの取得
print(my_dict["キー1"])  # 出力: バリュー1

# 新しいキー-バリューのペアを追加
my_dict["キー4"] = "バリュー4"

# キー-バリューのペアを削除
del my_dict["キー2"]

# すべてのキーを取得
keys = my_dict.keys()

# すべてのバリューを取得
values = my_dict.values()
PYTHON

IronPDF や IronOCR などの Iron Software 製品でも、辞書データ構造を活用して、データの管理やパフォーマンスを向上させることができます。(CSV、XML、JSONリスト)をワークブックとして開く ###

.3.1. CSVファイルを開く

新しいテキストファイルを作成し、名前と年齢のリストを追加してください(例を参照)。それを CSVList.csv として保存します。

Code Snippet related to 2.3. 辞書

あなたのコードスニペットはこのように見えるべきです

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-5.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\CSVList.csv");
WorkSheet workSheet = workBook.WorkSheets.First();
string cell = workSheet["A1"].StringValue;
Console.WriteLine(cell);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\CSVList.csv")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim cell As String = workSheet("A1").StringValue
Console.WriteLine(cell)
VB   C#

2.3.3. XMLファイルを開く 国のリストを含むXMLファイルを作成します。ルート要素は「countries」で、子要素は「country」です。各国は、コード、大陸など、その国を定義するプロパティを持ちます。

<?xml version="1.0" encoding="utf-8"?>
<countries xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <country code="ae" handle="united-arab-emirates" continent="asia" iso="784">United Arab Emirates</country>
        <country code="gb" handle="united-kingdom" continent="europe" alt="England Scotland Wales GB UK Great Britain Britain Northern" boost="3" iso="826">United Kingdom</country>
        <country code="us" handle="united-states" continent="north america" alt="US America USA" boost="2" iso="840">United States</country>
        <country code="um" handle="united-states-minor-outlying-islands" continent="north america" iso="581">United States Minor Outlying Islands</country>
</countries>
<?xml version="1.0" encoding="utf-8"?>
<countries xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <country code="ae" handle="united-arab-emirates" continent="asia" iso="784">United Arab Emirates</country>
        <country code="gb" handle="united-kingdom" continent="europe" alt="England Scotland Wales GB UK Great Britain Britain Northern" boost="3" iso="826">United Kingdom</country>
        <country code="us" handle="united-states" continent="north america" alt="US America USA" boost="2" iso="840">United States</country>
        <country code="um" handle="united-states-minor-outlying-islands" continent="north america" iso="581">United States Minor Outlying Islands</country>
</countries>
HTML

以下のコードスニペットをコピーして、XMLをワークブックとして開きます

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-7.cs
DataSet xmldataset = new DataSet();
xmldataset.ReadXml($@"{Directory.GetCurrentDirectory()}\Files\CountryList.xml");
WorkBook workBook = IronXL.WorkBook.Load(xmldataset);
WorkSheet workSheet = workBook.WorkSheets.First();
Dim xmldataset As New DataSet()
xmldataset.ReadXml($"{Directory.GetCurrentDirectory()}\Files\CountryList.xml")
Dim workBook As WorkBook = IronXL.WorkBook.Load(xmldataset)
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
VB   C#

2.3.5. JSONリストをワークブックとして開く JSON形式の国リストを作成

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-8.cs
[
    {
        "name": "United Arab Emirates",
        "code": "AE"
    },
    {
        "name": "United Kingdom",
        "code": "GB"
    },
    {
        "name": "United States",
        "code": "US"
    },
    {
        "name": "United States Minor Outlying Islands",
        "code": "UM"
    }
]
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'[{ "name": "United Arab Emirates", "code": "AE" }, { "name": "United Kingdom", "code": "GB" }, { "name": "United States", "code": "US" }, { "name": "United States Minor Outlying Islands", "code": "UM" }]
VB   C#

.3.6. JSONにマッピングする国モデルを作成する

Create Country Model related to 2.3. 辞書

以下はクラスコードスニペットです

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-9.cs
public class CountryModel
    {
        public string name { get; set; }
        public string code { get; set; }
    }
Public Class CountryModel
		Public Property name() As String
		Public Property code() As String
End Class
VB   C#

.3.8. JSONを国モデルのリストに変換するためにNewtonsoftライブラリを追加する

Add Newtonsoft Library To Convert Json related to 2.3. 辞書

.3.9 リストをデータセットに変換するには、リストの新しい拡張機能を作成する必要があります。「ListConvertExtension」という名前の拡張クラスを追加します。

Convert List To Dataset related to 2.3. 辞書

次に、このコードスニペットを追加してください

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-10.cs
public static class ListConvertExtension
    {
        public static DataSet ToDataSet<T>(this IList<T> list)
        {
            Type elementType = typeof(T);
            DataSet ds = new DataSet();
            DataTable t = new DataTable();
            ds.Tables.Add(t);
            //add a column to table for each public property on T
            foreach (var propInfo in elementType.GetProperties())
            {
                Type ColType = Nullable.GetUnderlyingType(propInfo.PropertyType) ?? propInfo.PropertyType;
                t.Columns.Add(propInfo.Name, ColType);
            }
            //go through each property on T and add each value to the table
            foreach (T item in list)
            {
                DataRow row = t.NewRow();
                foreach (var propInfo in elementType.GetProperties())
                {
                    row[propInfo.Name] = propInfo.GetValue(item, null) ?? DBNull.Value;
                }
                t.Rows.Add(row);
            }
            return ds;
        }
    }
Public Module ListConvertExtension
		<System.Runtime.CompilerServices.Extension> _
		Public Function ToDataSet(Of T)(ByVal list As IList(Of T)) As DataSet
			Dim elementType As Type = GetType(T)
			Dim ds As New DataSet()
'INSTANT VB NOTE: The variable t was renamed since Visual Basic does not allow local variables with the same name as method-level generic type parameters:
			Dim t_Conflict As New DataTable()
			ds.Tables.Add(t_Conflict)
			'add a column to table for each public property on T
			For Each propInfo In elementType.GetProperties()
				Dim ColType As Type = If(Nullable.GetUnderlyingType(propInfo.PropertyType), propInfo.PropertyType)
				t_Conflict.Columns.Add(propInfo.Name, ColType)
			Next propInfo
			'go through each property on T and add each value to the table
			For Each item As T In list
				Dim row As DataRow = t_Conflict.NewRow()
				For Each propInfo In elementType.GetProperties()
					row(propInfo.Name) = If(propInfo.GetValue(item, Nothing), DBNull.Value)
				Next propInfo
				t_Conflict.Rows.Add(row)
			Next item
			Return ds
		End Function
End Module
VB   C#

そして最後に、このデータセットをワークブックとして読み込みます。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-11.cs
StreamReader jsonFile = new StreamReader($@"{Directory.GetCurrentDirectory()}\Files\CountriesList.json");
var countryList = Newtonsoft.Json.JsonConvert.DeserializeObject<CountryModel[]>(jsonFile.ReadToEnd());
var xmldataset = countryList.ToDataSet();
WorkBook workBook = IronXL.WorkBook.Load(xmldataset);
WorkSheet workSheet = workBook.WorkSheets.First();
Dim jsonFile As New StreamReader($"{Directory.GetCurrentDirectory()}\Files\CountriesList.json")
Dim countryList = Newtonsoft.Json.JsonConvert.DeserializeObject(Of CountryModel())(jsonFile.ReadToEnd())
Dim xmldataset = countryList.ToDataSet()
Dim workBook As WorkBook = IronXL.WorkBook.Load(xmldataset)
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
VB   C#

保存とエクスポート

以下のコマンドのいずれかを使用して、Excelファイルを複数のファイル形式(「.xlsx」、「.csv」、「.html」)に保存またはエクスポートできます。

2.4.1. 「.xlsx」形式で保存 「.xlsx」形式で保存するには、saveAs関数を使用してください。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-12.cs
WorkBook workBook = WorkBook.Create(ExcelFileFormat.XLSX);
workBook.Metadata.Title = "IronXL New File";

WorkSheet workSheet = workBook.CreateWorkSheet("1stWorkSheet");
workSheet["A1"].Value = "Hello World";
workSheet["A2"].Style.BottomBorder.SetColor("#ff6600");
workSheet["A2"].Style.BottomBorder.Type = IronXL.Styles.BorderType.Dashed;

workBook.SaveAs($@"{Directory.GetCurrentDirectory()}\Files\HelloWorld.xlsx");
Dim workBook As WorkBook = WorkBook.Create(ExcelFileFormat.XLSX)
workBook.Metadata.Title = "IronXL New File"

Dim workSheet As WorkSheet = workBook.CreateWorkSheet("1stWorkSheet")
workSheet("A1").Value = "Hello World"
workSheet("A2").Style.BottomBorder.SetColor("#ff6600")
workSheet("A2").Style.BottomBorder.Type = IronXL.Styles.BorderType.Dashed

workBook.SaveAs($"{Directory.GetCurrentDirectory()}\Files\HelloWorld.xlsx")
VB   C#

2.4.2. CSVファイルとして保存 “.csv” 「.csv」形式で保存するために、SaveAsCsvを使用し、2つのパラメータを渡すことができます。1つ目のパラメータはファイル名とパス、2つ目のパラメータは区切り文字です。 (「,」または「」。 「」または「:」)

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-13.cs
workBook.SaveAsCsv($@"{Directory.GetCurrentDirectory()}\Files\HelloWorld.csv", delimiter: "|");
workBook.SaveAsCsv($"{Directory.GetCurrentDirectory()}\Files\HelloWorld.csv", delimiter:= "|")
VB   C#

2.4.3. JSON 形式で保存 “.json” ".json"形式で保存するには、次のようにSaveAsJsonを使用します

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-14.cs
workBook.SaveAsJson($@"{Directory.GetCurrentDirectory()}\Files\HelloWorldJSON.json");
workBook.SaveAsJson($"{Directory.GetCurrentDirectory()}\Files\HelloWorldJSON.json")
VB   C#

結果ファイルはこのように見えるべきです

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-15.cs
[
    [
        "Hello World"
    ],
    [
        ""
    ]
]
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'[["Hello World"], [""]]
VB   C#

2.4.4. XML “.xml”形式で保存 XMLに保存するには、次のようにSaveAsXmlを使用します。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-16.cs
workBook.SaveAsXml($@"{Directory.GetCurrentDirectory()}\Files\HelloWorldXML.XML");
workBook.SaveAsXml($"{Directory.GetCurrentDirectory()}\Files\HelloWorldXML.XML")
VB   C#

結果は次のようになります。

<?xml version="1.0" standalone="yes"?>
<_x0031_stWorkSheet>
  <_x0031_stWorkSheet>
    <Column1 xsi:type="xs:string" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">Hello World</Column1>
  </_x0031_stWorkSheet>
  <_x0031_stWorkSheet>
    <Column1 xsi:type="xs:string" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" />
  </_x0031_stWorkSheet>
</_x0031_stWorkSheet>
<?xml version="1.0" standalone="yes"?>
<_x0031_stWorkSheet>
  <_x0031_stWorkSheet>
    <Column1 xsi:type="xs:string" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">Hello World</Column1>
  </_x0031_stWorkSheet>
  <_x0031_stWorkSheet>
    <Column1 xsi:type="xs:string" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" />
  </_x0031_stWorkSheet>
</_x0031_stWorkSheet>
HTML

3. 高度な操作: 合計、平均、カウントなど。

一般的なExcel関数(SUM、AVG、Countなど)を適用し、それぞれのコードスニペットを見てみましょう。

3.1. 合計の例

このリストの合計を求めましょう。Excelファイルを作成し、「Sum.xlsx」と名付けて手動でこの数字のリストを追加しました。

Sum Example related to 3.1. 合計の例

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-18.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
decimal sum = workSheet["A2:A4"].Sum();
Console.WriteLine(sum);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim sum As Decimal = workSheet("A2:A4").Sum()
Console.WriteLine(sum)
VB   C#

3.2. Avg Example

3.2 平均の例 ###

同じファイルを使用して、平均を取得できます:

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-19.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
decimal avg = workSheet["A2:A4"].Avg();
Console.WriteLine(avg);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim avg As Decimal = workSheet("A2:A4").Avg()
Console.WriteLine(avg)
VB   C#

3.3. カウント例

同じファイルを使用して、シーケンス内の要素数を取得することもできます。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-20.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
decimal count = workSheet["A2:A4"].Count();
Console.WriteLine(count);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim count As Decimal = workSheet("A2:A4").Count()
Console.WriteLine(count)
VB   C#

3.4. 最大の例

同じファイルを使用して、セル範囲の最大値を取得できます:

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-21.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
decimal max = workSheet["A2:A4"].Max();
Console.WriteLine(max);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim max As Decimal = workSheet("A2:A4").Max()
Console.WriteLine(max)
VB   C#

– max関数の結果にtransform関数を適用することができます:

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-22.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
bool max2 = workSheet["A1:A4"].Max(c => c.IsFormula);
Console.WriteLine(max2);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim max2 As Boolean = workSheet("A1:A4").Max(Function(c) c.IsFormula)
Console.WriteLine(max2)
VB   C#

この例では、コンソールに「false」と出力します。

3.5. 最小限の例

同じファイルを使用して、セル範囲の最小値を取得することができます。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-23.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
decimal min = workSheet["A1:A4"].Min();
Console.WriteLine(min);
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim min As Decimal = workSheet("A1:A4").Min()
Console.WriteLine(min)
VB   C#

セルを整列する例

同じファイルを使用して、セルを昇順または降順に並べ替えることができます。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-24.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
workSheet["A1:A4"].SortAscending();
// workSheet["A1:A4"].SortDescending(); to order descending
workBook.SaveAs("SortedSheet.xlsx");
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
workSheet("A1:A4").SortAscending()
' workSheet["A1:A4"].SortDescending(); to order descending
workBook.SaveAs("SortedSheet.xlsx")
VB   C#

3.7. 条件文の例

同じファイルを使用して、Formulaプロパティを使ってセルの数式を設定または取得することができます:

.7.1. XML「.xml」形式で保存

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-25.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
int i = 1;
foreach (var cell in workSheet["B1:B4"])
{
    cell.Formula = "=IF(A" + i + ">=20,\" Pass\" ,\" Fail\" )";
    i++;
}
workBook.SaveAs($@"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx");
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\Sum.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim i As Integer = 1
For Each cell In workSheet("B1:B4")
	cell.Formula = "=IF(A" & i & ">=20,"" Pass"" ,"" Fail"" )"
	i += 1
Next cell
workBook.SaveAs($"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx")
VB   C#

.2. 前の例で生成されたファイルを使用して、セルの数式を取得できます:

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-26.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
foreach (var cell in workSheet["B1:B4"])
{
    Console.WriteLine(cell.Formula);
}
Console.ReadKey();
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
For Each cell In workSheet("B1:B4")
	Console.WriteLine(cell.Formula)
Next cell
Console.ReadKey()
VB   C#

3.8. 刈り取りの例

セル内の余分なスペースをすべて削除するtrim関数を適用するため、この列をsum.xlsxファイルに追加しました。

Trim Example related to 3.8. 刈り取りの例

このコードを使用して

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-27.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx");
WorkSheet workSheet = workBook.WorkSheets.First();
int i = 1;
foreach (var cell in workSheet["f1:f4"])
{
    cell.Formula = "=trim(D" + i + ")";
    i++;
}
workBook.SaveAs("editedFile.xlsx");
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\NewExcelFile.xlsx")
Dim workSheet As WorkSheet = workBook.WorkSheets.First()
Dim i As Integer = 1
For Each cell In workSheet("f1:f4")
	cell.Formula = "=trim(D" & i & ")"
	i += 1
Next cell
workBook.SaveAs("editedFile.xlsx")
VB   C#

したがって、同じ方法で数式を適用することができます。


マルチシートブックの操作

複数のシートを持つワークブックの操作方法について説明します。

1. データの順番などを合わせるために油圧文安技線を設き しェしーマールQ

次のような内容のxlsxファイルを作成しました。2つのシートが含まれています:「Sheet1」、「Sheet2」

これまでは WorkSheets.First() を使用して最初のシートを操作していました。この例ではシート名を指定してそのシートを操作します。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-28.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet2");
var range = workSheet["A2:D2"];
foreach (var cell in range)
{
    Console.WriteLine(cell.Text);
}
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx")
Dim workSheet As WorkSheet = workBook.GetWorkSheet("Sheet2")
Dim range = workSheet("A2:D2")
For Each cell In range
	Console.WriteLine(cell.Text)
Next cell
VB   C#

新しいシートをワークブックに追加する

ワークブックに新しいシートを追加することもできます:

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-29.cs
WorkBook workBook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx");
WorkSheet workSheet = workBook.CreateWorkSheet("new_sheet");
workSheet["A1"].Value = "Hello World";
workBook.SaveAs(@"F:\MY WORK\IronPackage\Xl tutorial\newFile.xlsx");
Dim workBook As WorkBook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx")
Dim workSheet As WorkSheet = workBook.CreateWorkSheet("new_sheet")
workSheet("A1").Value = "Hello World"
workBook.SaveAs("F:\MY WORK\IronPackage\Xl tutorial\newFile.xlsx")
VB   C#

エクセルデータベースと統合する

データベースにデータをエクスポート/インポートする方法を見てみましょう。

私は「TestDb」データベースを作成し、2つのカラム「Id」と「Name」を持つCountryテーブルを含めました。(int、identity), CountryName(文字列)

5.1. データベースからExcelシートにデータを入力する

ここでは、新しいシートを作成し、Country Tableからのデータで埋めます。

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-30.cs
TestDbEntities dbContext = new TestDbEntities();
var workbook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx");
WorkSheet sheet = workbook.CreateWorkSheet("FromDb");
List<Country> countryList = dbContext.Countries.ToList();
sheet.SetCellValue(0, 0, "Id");
sheet.SetCellValue(0, 1, "Country Name");
int row = 1;
foreach (var item in countryList)
{
    sheet.SetCellValue(row, 0, item.id);
    sheet.SetCellValue(row, 1, item.CountryName);
    row++;
}
workbook.SaveAs("FilledFile.xlsx");
Dim dbContext As New TestDbEntities()
Dim workbook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx")
Dim sheet As WorkSheet = workbook.CreateWorkSheet("FromDb")
Dim countryList As List(Of Country) = dbContext.Countries.ToList()
sheet.SetCellValue(0, 0, "Id")
sheet.SetCellValue(0, 1, "Country Name")
Dim row As Integer = 1
For Each item In countryList
	sheet.SetCellValue(row, 0, item.id)
	sheet.SetCellValue(row, 1, item.CountryName)
	row += 1
Next item
workbook.SaveAs("FilledFile.xlsx")
VB   C#

5.2. Excelシートからデータベースにデータを入力する

TestDbデータベースのCountryテーブルにデータを挿入する

:path=/static-assets/excel/content-code-examples/tutorials/csharp-open-write-excel-file-31.cs
TestDbEntities dbContext = new TestDbEntities();
var workbook = IronXL.WorkBook.Load($@"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx");
WorkSheet sheet = workbook.GetWorkSheet("Sheet3");
System.Data.DataTable dataTable = sheet.ToDataTable(true);
foreach (DataRow row in dataTable.Rows)
{
    Country c = new Country();
    c.CountryName = row[1].ToString();
    dbContext.Countries.Add(c);
}
dbContext.SaveChanges();
Dim dbContext As New TestDbEntities()
Dim workbook = IronXL.WorkBook.Load($"{Directory.GetCurrentDirectory()}\Files\testFile.xlsx")
Dim sheet As WorkSheet = workbook.GetWorkSheet("Sheet3")
Dim dataTable As System.Data.DataTable = sheet.ToDataTable(True)
For Each row As DataRow In dataTable.Rows
	Dim c As New Country()
	c.CountryName = row(1).ToString()
	dbContext.Countries.Add(c)
Next row
dbContext.SaveChanges()
VB   C#

さらに読む

IronXLの使用方法について詳しく知りたい場合は、このセクション内の他のチュートリアルや、ほとんどの開発者が始めるのに十分な例が見つかる私たちのホームページの例を参照することをお勧めします。

摂 Our APIリファレンス 以下のコンテンツを日本語に翻訳してください:

に特定のリファレンスを含む ワークブック クラス


チュートリアル クイック アクセス

Brand Visual Studio related to チュートリアル クイック アクセス

このチュートリアルをC#のソースコードとしてダウンロード

このチュートリアルのための完全な無料C# for Excelのソースコードは、Visual Studio 2017プロジェクトファイルとして圧縮された状態でダウンロード可能です。

ダウンロード

このチュートリアルをGitHubで探索する

このプロジェクトのソースコードはGitHubでC#およびVB.NETで利用可能です。

このコードを使用すると、わずか数分で簡単に始められます。このプロジェクトはMicrosoft Visual Studio 2017プロジェクトとして保存されていますが、どの.NET IDEとも互換性があります。

GitHubでC#を使用してExcelファイルを開く方法および書き込む方法
Github Icon related to チュートリアル クイック アクセス
Documentation related to チュートリアル クイック アクセス

IronXLのAPIリファレンス

IronXLのすべての機能、名前空間、クラス、メソッドフィールド、列挙型の詳細を詳述したAPIリファレンスを探索してください。

APIリファレンスを表示
.NET Excelライブラリは、データをウェブアプリケーションやビジネスシステムに取り込んだり、出力したりする方法を革命的に変えることができます。

イライジャ・ウィリアムズ

プロダクト開発エンジニア

イライジャは、大規模な企業の財務報告システムを担当する開発およびテストチームのエンジニアです。イライジャは、IronXLライブラリを早期に採用し、Excel報告インターフェースの中心に組み込んでいます。