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

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

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

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

Q&A

2回答

2612閲覧

C#でCSVファイルを出力したい

退会済みユーザー

退会済みユーザー

総合スコア0

C#

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

0グッド

0クリップ

投稿2020/06/11 00:28

前提・実現したいこと

C#でCSVファイルを読みこみ、二次元配列に格納しテキストボックスに出力したい

発生している問題・エラーメッセージ

while文のstring line = sr.ReadLine(); string[] values = line.Split(',');の部分で
いったんCSVファイルを読み込んでしまっているため、table[columu, row] = values[row];
の部分で二次元配列にCSVファイルの一番下の行だけが格納されてしまっている。

該当のソースコード

C#
ソースコード

StreamReader sr = new StreamReader(openFileDialog1.FileName,          Encoding.GetEncoding("Shift_JIS")); { int columu = 0; int row = 0; string[] values = new string[row]; //テーブルの行数(columu)と列数(row)を取得 while (!sr.EndOfStream) { int rowTotal = 0; string line = sr.ReadLine(); string[] values = line.Split(','); for (int i = 0; i < values.Length; i++) { rowTotal = rowTotal + 1; } columu = columu + 1; row = rowTotal / columu; } string[,] table = new string[columu, row]; for (columu = 0;columu < table.GetLength(0);columu++) { string line = sr.ReadLine(); string[] values = line.Split(','); for (row = 0; row < table.GetLength(1); row++) { table[columu,row] = values[row] textBox2.Text += table[columu, row].ToString(); } textBox2.Text += Environment.NewLine; } }

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

YAmaGNZ

2020/06/11 00:36

同じループで行えばいいだけでは?
退会済みユーザー

退会済みユーザー

2020/06/11 00:40

今回はlistを使っていないので(じゃあlistを使えという話ですが)、while文で、いったん配列の大きさを取得しています。配列の大きさを取得する処理と、配列に格納する処理は同時には行えないと判断しました。 (C#を初めて二週間のため、あまり深くは理解していません。すみません)
Zuishin

2020/06/11 00:44 編集

List を使えという話ですね。使わない理由がありません。LINQ を使うなら話は別ですが。
退会済みユーザー

退会済みユーザー

2020/06/11 00:56

いまさらながらのお願いですが、コードは ``` と ``` で囲ってもらえませんか(``` はバッククォート 3 つ)。インデントされて見やすくなるので。インデントされてないコードは質問者さん自身も見る気がしないのでは? 親切な回答者の方は読んでくれているようですが・・・
guest

回答2

0

どうしてもListを使いたくないのであれば、こんな感じでどうでしょう

C#

1 int columu = 0; 2 int row = 0; 3 //テーブルの行数(columu)と列数(row)を取得//←行と列が逆なんじゃ? 4 var values = File.ReadAllLines("test.csv", Encoding.GetEncoding("shift-jis")); 5 row = values.Length; 6 columu = values[0].Split(',').Length; 7 8 string[,] table = new string[columu, row]; 9 for (row = 0; row < table.GetLength(1); row++) { 10 var tmp = values[row].Split(','); 11 for (columu = 0; columu < table.GetLength(0); columu++) { 12 table[columu, row] = tmp[columu]; 13 Console.Write(table[columu, row]); 14 } 15 Console.WriteLine(); 16 } 17 Console.Read();

投稿2020/06/11 12:57

Hey_CH

総合スコア437

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

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

0

ファイルのデータは順番に読まれますんで、全部読んでしまったらそれ以上は読めません。
それをどうにかするなら、ファイルをオープンし直すか、ファイルポインタを0に(最初に戻す)する必要があります。

#ツッコミどころが多いコードですが。。

投稿2020/06/11 00:41

編集2020/06/11 00:42
y_waiwai

総合スコア88042

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問