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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

C#

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

Q&A

解決済

2回答

4142閲覧

C# CSVファイルの先頭行に1行挿入するプログラム

sasa_111

総合スコア1

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

C#

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

0グッド

0クリップ

投稿2022/05/10 01:55

編集2022/05/10 07:55

C#で質問です

CSVファイルをドラッグアンドドロップすると
そのファイルの先頭行に1行任意の行を挿入するプログラムを作りたいのですが、
現在先頭ではなく末尾に挿入されてしまい、困っています

どなたかアドバイスをいただけないでしょうか?
現在書いているコードです↓

private void Form1_DragDrop(object sender,System.Windows.Forms.DragEventArgs e) { //コントロール内にドロップされたとき実行される //ドロップされたすべてのファイル名を取得する string[] fileName =(string[])e.Data.GetData(DataFormats.FileDrop, false); string str = fileName[0]; //ファイルのパスまるごと string FileName = Path.GetFileName(str);//ファイルの名称を抜き出す while (true) { //if (sr.ReadLine() == FileName) //ReadLineは1行取得次の行を取得しにいく if ("test.csv" == FileName) { //CSVデータをリストで用意 List<string> lines = new List<string>(); lines.Add("ファイル名,製品名"); //StreamWriterでファイルをオープンし、WriteLine でデータを1行づつファイルに書き込み using (StreamWriter sw = new StreamWriter(@"C:\Users\sa\Desktop\test.csv", true, Encoding.GetEncoding("shift-jis"))) { foreach (string line in lines) { sw.WriteLine(line); } } break; //ファイル名と行が一致すればブレイク } else if ("export_title.txt" == FileName) { break; //ファイル名と行が一致すればブレイク } } } }

}

2022/5/10 16:50
こちらでご教授いただき、
最終的にこのように解決しました

private void Form1_DragDrop(object sender, System.Windows.Forms.DragEventArgs e) { //コントロール内にドロップされたとき実行される //ドロップされたすべてのファイル名を取得する string[] fileName = (string[])e.Data.GetData(DataFormats.FileDrop, false); string str = fileName[0]; //ファイルのパスまるごと string FileName = Path.GetFileName(str);//ファイルの名称を抜き出す string nakami = System.IO.File.ReadAllText(str, Encoding.GetEncoding("shift-jis"));//ファイルの中身をすべて読み込む while (true) { if ("test.csv" == FileName) //●CSVのファイル名はファイルごとに変更すること { nakami = "1行目に挿入されるヘッダ行,title\r\n" + nakami; //★挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する MessageBox.Show("ヘッダの挿入が完了しました", "完了", MessageBoxButtons.OK, MessageBoxIcon.None); break; } else if ("export_title.csv" == FileName)//●CSVのファイル名はファイルごとに変更すること { nakami = "ここに任意の内容を記載1,ここに任意の内容を記載2\r\n" + nakami; //★挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する MessageBox.Show("ヘッダの挿入が完了しました", "完了", MessageBoxButtons.OK, MessageBoxIcon.None); break; } else if ("export_hedda.csv" == FileName)//●CSVのファイル名はファイルごとに変更すること { nakami = "新しい行です。,title\r\n" + nakami; //★挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する MessageBox.Show("ヘッダの挿入が完了しました", "完了", MessageBoxButtons.OK, MessageBoxIcon.None); break; } else { MessageBox.Show("該当するファイルのヘッダはありません", "エラー", MessageBoxButtons.OK, MessageBoxIcon.None); break; } } }

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

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

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

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

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

dodox86

2022/05/10 02:53

質問の本題とはそれますが、ドラッグ&ドロップしたファイルのファイル名が"test.csv"、"export_title.txt"のどちらでも無いときはwhile(true){}で永久ループするように見えますが良いのでしょうか。
sasa_111

2022/05/10 07:50

ご指摘ありがとうございます ファイル名がそれ以外の時はループから出るようにコードを追記しました
guest

回答2

0

CSVは要するにテキスト・ファイルなんだから...

C#

1// Program.cs 2using System.IO; 3 4class Program { 5 static void Main() { 6 var builder = new System.Text.StringBuilder(); 7 builder.AppendLine("// 実行するたびにこの一行が先頭に追加されます"); 8 // 丸ごと読んで 9 using( var stream = System.IO.File.OpenText("Program.cs") ) { 10 builder.Append(stream.ReadToEnd()); 11 } 12 // (追加した一行と共に)丸ごと書き出す 13 using (var stream = new System.IO.StreamWriter("Program.cs") ) { 14 stream.Write(builder.ToString()); 15 } 16 System.Console.Write(builder.ToString()); 17 } 18}

投稿2022/05/10 03:59

episteme

総合スコア16614

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

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

0

ベストアンサー

lines.Add("ファイル名,製品名");

Microsoft のドキュメントに "List<T> の末尾にオブジェクトを追加します。" と書いてあります。

Add メソッドに代えて Insert メソッドを使ってはいかがですか?

投稿2022/05/10 02:05

編集2022/05/10 02:08
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

YAmaGNZ

2022/05/10 02:40

StreamWriterを追記で作成して書いているだけなのでListのAddの方法は関係ないのではないでしょうか?
sasa_111

2022/05/10 02:42

ご回答いただきありがとうございます すみません、作成物のイメージですが 例えばドロップしてきたCSVファイルが10行あれば、1行目に任意行を挿入し、 もともとの10行は1行ずつ下にずれるイメージとなります Insertを調べてみたのですが、文字列内の任意の場所にいれれるようなので 少し違うかもしれません、せっかくご回答いただいたのに申し訳ありません
退会済みユーザー

退会済みユーザー

2022/05/10 03:30 編集

lines.Add("ファイル名,製品名"); の lines にはドラッグ&ドロップした CSV ファイルの各行が List<string> 型として取得されていると思っていたのですが、Add する時点では空だったのでしょうか?  であれば、まずは CSV ファイルを読んで List<string> 型のオブジェクトを作成してから、Insert してはいかがですか?
退会済みユーザー

退会済みユーザー

2022/05/10 03:41 編集

CSV はただのテキストファイルなので、一行先頭に追加するだけなら、List<string> 等は使わなくても、もっと簡単にできます。以下の記事を見てください。 テキストファイルから1行削除する、先頭に1行追加する https://dobon.net/vb/dotnet/file/edittextfile.html
sasa_111

2022/05/10 04:26

ご回答ありがとうございます 下記の用に書き直してみたのですが、2つ問題が発生しました ①追加したい内容を日本語で入力すると文字化けしてしまう ②カンマ区切りでかいても1マス内にすべて入力されてしまう(CSVファイルはエクセルで開いています) どこが原因かご教授いただけますでしょうか? private void Form1_DragDrop(object sender, System.Windows.Forms.DragEventArgs e) { //コントロール内にドロップされたとき実行される //ドロップされたすべてのファイル名を取得する string[] fileName = (string[])e.Data.GetData(DataFormats.FileDrop, false); string str = fileName[0]; //ファイルのパスまるごと string FileName = Path.GetFileName(str);//ファイルの名称を抜き出す string nakami = System.IO.File.ReadAllText(str);//ファイルの中身をすべて読み込む while (true) { //if (sr.ReadLine() == FileName) //ReadLineは1行取得次の行を取得しにいく if ("test.csv" == FileName) { nakami = "新しい行です。,title\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami);//テキストファイルに上書き保存する break; //ファイル名と行が一致すればブレイク } else if ("export_title.csv" == FileName) { nakami = "新しい行です。\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami);//テキストファイルに上書き保存する break; //ファイル名と行が一致すればブレイク } else if ("export_hedda.csv" == FileName) { nakami = "新しい行です。\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami);//テキストファイルに上書き保存する break; //ファイル名と行が一致すればブレイク } } }
退会済みユーザー

退会済みユーザー

2022/05/10 05:11

> ①追加したい内容を日本語で入力すると文字化けしてしまう 質問者さんが使っている File.WriteAllText(String, String) メソッドはバイト順マーク (BOM) なしのUTF-8 エンコーディングを使用します。それでできたファイルを Excel で読んでいると思いますが、Excel はエンコーディングを Shift_JIS だと解釈した結果文字化けしたと思います。File.WriteAllText メソッドには第 3 引数にエンコーディングを指定できるオーバーロードがありますので、それに希望のエンコーディング(Shift_JIS ですか?)を指定して使ってみてください。 > ②カンマ区切りでかいても1マス内にすべて入力されてしまう(CSVファイルはエクセルで開いています) ヘッダ行のことですか? コードを見るとカンマが入ってないものがありますけど? 作成した CSV ファイルをメモ帳で開いて、期待通りカンマが入っているか確認してください。
sasa_111

2022/05/10 06:12

ご回答ありがとうございます >① System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する このように改善したところ、文字化けが改善されました!ありがとうございます! >② ①を改善したところ、こちらも一緒に改善されました!ありがとうございます また、もう1つ質問させていただきたいのですが、 ドラッグアンドドロップしたCSVファイル内に日本語のセルがあると このプログラムを実行すると、そのセルだけ「???」という表示になってしまいます もしよろしければこちらもご教授いただいてもよろしいでしょうか?
退会済みユーザー

退会済みユーザー

2022/05/10 06:28

> ドラッグアンドドロップしたCSVファイル内に日本語のセルがあるとこのプログラムを実行すると、そのセルだけ「???」という表示になってしまいます それはたぶん「ドラッグアンドドロップしたCSVファイル」のエンコーディングと、質問者さんが使っている File.ReadAllText メソッドのエンコーディングの問題と思います。 File.ReadAllText メソッドにも第 2 引数にエンコーディングを指定できるオーバーロードがありますので、元の CSV ファイルのエンコーディングが Shift_JIS なら、 File.ReadAllText メソッドの第 2 引数にも Shift_JIS を指定して試してみてください。
sasa_111

2022/05/10 06:40

ご回答いただきありがとうございます 第二引数に指定したところ、無事文字化けが解消されました!! この度は色々ご教授いただきありがとうございました ※一応メモがわりに最終版をこちらに貼らせていただきます private void Form1_DragDrop(object sender, System.Windows.Forms.DragEventArgs e) { //コントロール内にドロップされたとき実行される //ドロップされたすべてのファイル名を取得する string[] fileName = (string[])e.Data.GetData(DataFormats.FileDrop, false); string str = fileName[0]; //ファイルのパスまるごと string FileName = Path.GetFileName(str);//ファイルの名称を抜き出す string nakami = System.IO.File.ReadAllText(str, Encoding.GetEncoding("shift-jis"));//ファイルの中身をすべて読み込む while (true) { //if (sr.ReadLine() == FileName) //ReadLineは1行取得次の行を取得しにいく if ("test.csv" == FileName) { nakami = "新しい行です。,title\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する break; } else if ("export_title.csv" == FileName) { nakami = "新しい行です。,title\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する break; } else if ("export_hedda.csv" == FileName) { nakami = "新しい行です。,title\r\n" + nakami; //挿入内容 System.IO.File.WriteAllText(str, nakami, Encoding.GetEncoding("shift-jis"));//テキストファイルに上書き保存する break; } } }
退会済みユーザー

退会済みユーザー

2022/05/10 06:57

> ※一応メモがわりに最終版をこちらに貼らせていただきます 質問欄を編集して「最終的にこのようにして解決した」ということで追記した方が良いと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問