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

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

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

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

Q&A

解決済

2回答

948閲覧

csvファイルを読み込んでtxt形式で保存したい

nkt070408

総合スコア29

C#

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

0グッド

1クリップ

投稿2017/12/12 01:12

csvファイルを読み込み、カンマを削除してtxtファイルとして保存するものを作っているのですがうまくいきません。csvファイルを読み込んでリストに格納してそれを書き込むと考え、それを実装している途中でわけがわからなくなり、完全に行き詰ってしまいました。作成途中のソースを書いておくので何かアドバイスやヒントをいただけると幸いです。

C#

1using System; 2using System.Collections; 3using System.IO; 4 5namespace csv_txt 6{ 7 class Csv_Conv 8 { 9 // file_name...読み込むcsvファイル名 10 public void txt_creation(string file_name) 11 { 12 // リストの作成 13 ArrayList lineCsv = new ArrayList(); 14 15 // csvを読み取るためにリーダを作成 16 var csvReader = new 17         StreamReader(file_name,System.Text.Encoding.Default); 18 19 // 1行ずつすべての行を読み込む 20 string sLine = csvReader.ReadToEnd(); 21 22 while (sLine != null) 23 { 24 //sLine = csvReader.ReadLine(); 25 26 lineCsv.Add(sLine.Split(',')); 27 28 Console.WriteLine(sLine); 29 } 30 31 Console.ReadKey(); 32 } 33 } 34} 35 36

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

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

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

下記のような質問は推奨されていません。

  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。

hsk

2017/12/12 02:36 編集

csvReader.ReadLine(); をコメントアウトして、ループの外でReadToEndによって全部読みだす変更はどのような意図からでしょうか?もしかして読み込みたいCSVファイルは1行だけのものですか? ループで文字列配列のリストを作ろうとしているようで、そのわけがわからなくなった点ですが、ArrayList は配列を格納するためのリストなのではなく(できなくもないですが)、リストを配列的に扱えるリストである、と説明されたら、整理がつくでしょうか?却ってわけわからなくなってしまいましたかね^^;
guest

回答2

2

ベストアンサー

csvファイルを読み込み、カンマを削除してtxtファイルとして保存するものを作っているのですがうまくいきません。

それにどういう意味があるのか疑問ですが、その話はちょっと置いといて・・・

CSV ファイルを一行ずつ読んで文字列を作り、String.Split メソッドでその文字列を区切るといった方法を考えていると思いますが、改行コードやデリミタ(コンマのような区切り文字)がフィールド値の中にあったり、改行コードが異なったり(例: Windows は CR + LF、Unix は LF)するのに対応する場合、そのような単純な方法は使えません。

改行コードやデリミタがフィールド値の中にある場合、フィールド値をダブルクォート (") で囲むと言った約束を設けて対応しますが、そのような CSV ファイルの処置が可能なコードを自力で書くのは簡単ではありません。

なので、既存のパーサーを使うのがよさそうです。既存のパーサーにはいろいろなものがあります。自分のお勧めは以下の記事に書いた TextFieldParser です。何といっても Microsoft のライブラリなので、C# のアプリならこれを使うのが一番無難そうな気がします。

CSV パーサー
http://surferonwww.info/BlogEngine/post/2010/10/28/CSV-parser.aspx

使い方は上の記事のコード例を見てください。上の記事では DataTable に格納してますが、記事のコードの、

string[] fields = tfp.ReadFields();

で各行のフィールドの文字列の配列を取得できますので、それを処置することで望むことができるはずです。

投稿2017/12/12 02:07

編集2017/12/12 02:08
退会済みユーザー

退会済みユーザー

総合スコア0

bochan2, nkt070408👍を押しています

下記のような回答は推奨されていません。

  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。

回答へのコメント

nkt070408

2017/12/12 02:40

回答ありがとうございます。 わざわざご丁寧にありがとうございます。TextFieldParserを使って自分の望むものを作ることができました。DataTableで少し引っかかっていたので助かりました。
guest

1

単純に取り除くならString.Replace メソッドでもいいのですが、フィールド内に「,」が含まれるなどするなら、TextFieldParserなりCsvHelperを使ったほうがいいでしょう。

.NET Framework 2.0以降で、TextFieldParserクラスを使用する方法
https://dobon.net/vb/dotnet/file/readcsvfile.html#section7

C# で CSV を扱うのに CsvHelper を使う - dunno logs
http://dany1468.hatenablog.com/entry/2013/07/15/175319

投稿2017/12/12 01:49

x_x

総合スコア13747

nkt070408👍を押しています

下記のような回答は推奨されていません。

  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

また依頼した内容が修正された場合は、修正依頼を取り消すようにしましょう。

回答へのコメント

nkt070408

2017/12/12 02:37

回答ありがとうございます。 TextFieldParserを調べて作り直してみたところ、詰まっていた箇所が改善され、望むものを作成することができました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.60%

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

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

質問する

同じタグがついた質問を見る

C#

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