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

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

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

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

2回答

9508閲覧

C# excelに2次配列を出力したい

taaaaaa6

総合スコア9

C#

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2020/08/24 07:34

前提・実現したいこと

VisualStudioにてc#でexcelに2次配列を出力しようとしています。
closedxmlを使用して2次配列をセルに挿入していますが、
縦1列にデータが入ってしまいます。
以下のように2次配列[0,1]をB1に、[1,1]をB2に表示させたいです。

実現したいexcel図
__A  B
1 あ  1
2 い  2

現状
__A  B
1 あ
2 1
3 い
4 2

ご教示お願いいたします。

該当のソースコード

C#

1var query = dt.AsEnumerable() 2 .Select(x => new { name = x.Field<string>("A"), 3 startValue = DateTime.Parse(x.Field<string>("B")), 4 endValue = DateTime.Parse(x.Field<string>("C")) }); 5 int i = 0; 6 7 object[,] result = new object[dt.Rows.Count, 2]; 8 foreach (var row in query) 9 { 10 int j = 0; 11 result[i, j] = row.name; 12 j += 1; 13 result[i, j] = (row.endValue - row.startValue).ToString(); 14 15 i += 1; 16 } 17 IXLWorksheet ws = wb.Worksheet(4); 18 ws.Cell(1, 1).Value = result;

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

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

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

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

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

guest

回答2

0

ベストアンサー

CellのInsertDataメソッドを使用してください。

c#

1 var listVars = new List<Object[]>() 2 { 3 new object[] {"あ", "1"}, 4 new object[] {"い", "2"}, 5 }; 6 7 using (var book = new XLWorkbook()) 8 { 9 var sheet1 = book.AddWorksheet("sheet1"); 10 sheet1.Cell("A1").InsertData(listVars.ToArray()); 11 book.SaveAs("c:/test/test.xlsx"); 12 }

投稿2020/08/24 08:23

編集2020/08/24 08:34
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

taaaaaa6

2020/08/25 00:19

var result = new List<object[]>(); foreach (var row in query) { result.Add(new object[] {row.name,(row.endValue-row.startValue) }); } listに入れてInsertDataで思う通りに出力できました! ありがとうございました。
guest

0

貼り付け範囲を明確にしてみるのはいかがでしょうか。
二次元配列をセルに一括出力する

投稿2020/08/24 08:01

radames1000

総合スコア1925

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

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

taaaaaa6

2020/08/25 00:14

ws.Range(1, 1, dt.Rows.Count, 2).Value = result; で範囲を設定しましたがうまくいかなかったです。。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問