質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

Q&A

解決済

3回答

3698閲覧

Excelを読み、行ごとにセルを処理したいです。

cancat

総合スコア313

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

WPF

Windows Presentation Foundation (WPF) は、魅力的な外観のユーザー エクスペリエンスを持つ Windows クライアント アプリケーションを作成するための次世代プレゼンテーション システムです

0グッド

0クリップ

投稿2017/09/08 01:53

こんにちは。
Windows10でWPFのアプリケーションを開発しています。
Visual Studio 2017 Communityを使っています。

###前提・実現したいこと
Excelを読み、行ごとにセルを処理したいです。

###試したこと
using ClosedXML.Excel;
で読んでみました。

###発生している問題・エラーメッセージ
行ごとのセルを配列にしたい。
行を取得するプロパティとか変数を見つけたいです。

###該当のソースコード

C#

1using ClosedXML.Excel; 2 3var wb = new XLWorkbook(path); 4foreach (var worksheet in wb.Worksheets) 5{ 6 int lastRow = worksheet.LastRowUsed().RowNumber(); 7 for (int i = 1; i <= lastRow; i++) 8 { 9 //ここで1行を処理したい。 10 IXLCell cell = worksheet.Cell(i, 1);//<--これだとセルの1つめのみを取得する。すべてのセルを取得したい。 11 Console.WriteLine(cell.Value); 12 } 13} 14

###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft Visual Studio Community 2017
Version 15.0.26228.9 D15RTWSVC
Microsoft .NET Framework
Version 4.6.01586

です。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

質問(ClosedXML の使い方)に対する直接の回答ではありませんが・・・

行ごとのセルを配列にしたい。

Excel を操作するのではなく、Excel からデータを取得してきて、そのデータを .NET Framwwork のアプリ内で配列にしたいという理解でいいですか?

であれば、ADO.NET + ACE(Excel 2003 なら JET でも可)を使うという手段があります。

.NET のプログラマとしては馴染みのある ADO.NET を使った方が、ClosedXML を使うより開発工数も保守工数も少なくて済むのではないかと思います。

ACE とは何かとか、その導入方法は以下の記事を見てください。タイトルが Access ... となってますが Excel でも ACE(または JET)を使います。

Access 2007 の DB を利用するアプリ開発
http://surferonwww.info/BlogEngine/post/2011/11/08/Development-of-application-which-uses-accdb-file-of-Access-2007.aspx

使い方の具体例は以下の記事を見てください。

ACE OleDb で Excel のブック作成
http://surferonwww.info/BlogEngine/post/2012/01/26/Creating-Excel-workbook-by-using-ACE-OleDb-provider.aspx

Visual Basic .NET と ADO.NET を使用して Excel ブックのレコードの取得と変更を行う方法
https://support.microsoft.com/ja-jp/help/316934/how-to-use-ado-net-to-retrieve-and-modify-records-in-an-excel-workbook

投稿2017/09/08 02:11

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2017/09/08 02:47

ADOというのがあるのですね。知りませんでした。参考になります。ありがとうございます。
guest

0

確認していませんが、こちらが参考になりませんか?
http://nineworks2.blog.fc2.com/blog-entry-61.html

投稿2017/09/08 02:13

kikukiku

総合スコア514

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2017/09/08 04:25

ありがとうございます。まだスタートしたところで、いろいろ情報入れてます。参考になります。
guest

0

ベストアンサー

行を取得するには下記の様にしてみては如何でしょうか?

c#

1//ここで1行を処理したい。 2var row1 = worksheet.Row(i); 3Console.WriteLine(row1.FirstCell().Value);//最初のセルの値 4Console.WriteLine(row1.Cell(2).Value);//2番目のセルの値

投稿2017/09/08 02:11

motuo

総合スコア3027

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cancat

2017/09/08 02:53

ありがとうございます。 最後のセルの番号はどう取得したらよいでしょう? row1.LastCellUsed()はIXLCellでintを取り出すのに苦戦中です。
motuo

2017/09/08 02:58

row1.LastCellUsed().Address.ColumnNumberでとれると思いますよ。例えば、E1が最後のセルの場合は5が取得できます。
cancat

2017/09/08 04:24

できました。ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問