Excel ワークブック間でワークシートをコピーする

導入

Excel ブック間でワークシートを手動でコピーしたことがありますか? 一輪車に乗りながらジャグリングをしようとしているようなものです。 しかし、Aspose.Cells for .NET を使用すると、このタスクを簡素化し、バターを切るようにスムーズに行うことができます。 大規模なデータ セットを管理する場合でも、情報を統合する必要がある場合でも、ワークブック間でワークシートをコピーすると、多くの時間を節約できます。 このチュートリアルでは、Aspose.Cells for .NET を使用してこれを行う方法を詳しく説明します。 このガイドを読み終える頃には、Excel タスクを簡単にこなせるようになっているでしょう。

前提条件

コードに進む前に、開始するための適切なツールが揃っていることを確認しましょう。

  • Aspose.Cells for .NET: ダウンロードできますここ.
  • Visual Studio または .NET フレームワークをサポートする任意の IDE。
  • 有効な免許証または一時ライセンスAspose.Cells の全機能をテストしたい場合。
  • C# と .NET フレームワークの基本的な理解。

また、Aspose.Cells ドキュメント詳細についてはこちらをご覧ください。

パッケージのインポート

コーディングを始める前に、必要なパッケージをインポートする必要があります。これは、旅行前に荷物をまとめるようなものです。スムーズに進めるためには適切なツールが必要です。

using Aspose.Cells;

このシンプルなコード行は、これから取り組むすべての Excel マジックへの入り口となる Aspose.Cells ライブラリをインポートします。

これですべての設定が終わったので、Excel ブック間でワークシートをコピーする手順を見ていきましょう。各手順は簡単に理解できるように細分化されています。そのため、Aspose.Cells を初めて使用する場合でも、手順を追うことができます。

ステップ1: ドキュメントディレクトリを設定する

まず、ファイルの保存場所を定義する必要があります。この手順は、宝探しの地図を選択するようなもので、コードにワークブックを見つけて保存する場所を指示します。

//ドキュメント ディレクトリへのパス。
string dataDir = "YOUR DOCUMENT DIRECTORY";

この行では、"YOUR DOCUMENT DIRECTORY"Excel ファイルへの実際のパスを入力します。ここからワークブックが読み込まれ、保存されます。

ステップ2: 最初のワークブックを開く

次に、コピーするワークシートが含まれている最初のワークブックを開きます。これは、フォルダーを開いて紙を 1 枚取り出すようなものだと考えてください。

string InputPath = dataDir + "book1.xls";
//ワークブックを作成します。
//最初のブックにファイルを開きます。
Workbook excelWorkbook0 = new Workbook(InputPath);

ここで読み込み中ですbook1.xls(ファイルがディレクトリに存在することを確認してください)新しいWorkbookオブジェクトと呼ばれるexcelWorkbook0これは、コピーするワークシートが含まれているソース ワークブックです。

ステップ3: 2番目のワークブックを作成する

最初のワークブックが開いたので、コピーしたワークシートを貼り付ける別の空のワークブックを作成します。これは、データを転送する新しい空のノートブックを開くと考えてください。

//別のワークブックを作成します。
Workbook excelWorkbook1 = new Workbook();

この行は、次の名前の空のワークブックを作成します。excelWorkbook1最初のブックから移動した後、コピーしたワークシートはここに保存されます。

ステップ4: ワークシートをコピーする

魔法の登場です! このステップでは、実際に最初のワークブックのワークシートを 2 番目のワークブックにコピーします。これは、あるノートブックから別のノートブックにメモを転送するようなものです。

//最初の本の最初のシートを 2 番目の本にコピーします。
excelWorkbook1.Worksheets[0].Copy(excelWorkbook0.Worksheets[0]);

ここで何が起こっているのでしょうか?コードは最初のワークシートをexcelWorkbook0それを最初のシートにコピーしますexcelWorkbook1すごく簡単ですよね?

ステップ5: 新しいワークブックを保存する

最後に、コピーしたワークシートを含む 2 番目のワークブックを保存します。これは、新しく書き込んだメモをコンピューターの新しいフォルダーに保存するようなものです。

//ファイルを保存します。
excelWorkbook1.Save(dataDir + "CopyWorksheetsBetweenWorkbooks_out.xls");

これにより、コピーされたワークシートを含む2番目のワークブックが、新しいファイルに保存されます。CopyWorksheetsBetweenWorkbooks_out.xls名前は自由に変更してください。

結論

これで完了です。Aspose.Cells for .NET を使用して、ある Excel ブックから別の Excel ブックにワークシートをコピーできました。これは簡単なプロセスで、特に複雑なスプレッドシートや大きなスプレッドシートで作業する場合に、手動でコピーして貼り付ける手間が省けます。Aspose.Cells for .NET は、シートのコピー、ワークブックの結合、またはより高度なタスクの実行など、Excel ファイルを簡単に操作できる強力なツールです。

コーディングは、小さなステップに分割すると簡単になります。次に Excel ファイルの管理が必要になったときには、プロのように扱えるようになります。

よくある質問

複数のワークシートを一度にコピーできますか?

はい、ソースブック内のワークシートをループして、コピー先のワークシートにコピーすることができます。各ワークシートには独自のCopy方法。

すでにデータがあるワークブックにワークシートをコピーできますか?

もちろんです! すでにデータが含まれている場合でも、ワークシートを既存のワークブックにコピーできます。正しいワークシート インデックスを指定するだけです。

この機能には有料ライセンスが必要ですか?

Aspose.Cellsの無料版でも基本的な機能は使えますが、有料版を購入することをお勧めします。一時ライセンスまたは、フル機能を利用し、透かしなどの制限を回避するには、有料ライセンスを購入してください。

グラフや画像を含むワークシートをコピーできますか?

はい。Aspose.Cells は、グラフ、画像、その他のオブジェクトを含むワークシートのコピーを完全にサポートしています。コピー処理中はすべてが保持されます。

ワークシートを新しいワークブックの特定の位置にコピーするにはどうすればよいですか?

コピーしたワークシートを配置するインデックスを指定するには、Worksheets.AddCopyメソッドにより、シートの配置場所をより細かく制御できるようになります。