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

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

ただいまの
回答率

89.25%

c#でcsvファイルを読み込み、json形式で出力したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 96

aruto417

score 1

前提・実現したいこと

C#でcsvファイルを読み込みjson形式で出力したいです。
json形式にする上で、csvファイルの1行目をkeyとし、2行目以降をvalueとして出力したいのですがいい方法はないでしょうか。
例)以下のようなcsvファイルを読み込み
aaa,bbb,ccc
1,2,3
50,70,90
以下のような形式で出力したいです。
{"aaa": "1" ,"bbb": "2", "ccc": "3" }
{"aaa": "50" ,"bbb": "70", "ccc": "90" }

該当のソースコード

using System.Collections.Generic;
using System.IO;
using System.Json;
using Newtonsoft.Json;

namespace CsvRead
{
    class Test
    {
        static void Main()
        {
            StreamReader sr = new StreamReader(@"test.csv", System.Text.Encoding.GetEncoding("shift_jis"));
            {
                while (!sr.EndOfStream)
                {

                    string line = sr.ReadLine();

                    string[] values = line.Split(',');
                    List<string> lists = new List<string>();
                    lists.AddRange(values);

                    string jsonString = JsonConvert.SerializeObject(lists);

                    System.Console.WriteLine(jsonString);


                }
            }

        }
    }
} 

試したこと

csvファイルを読み込み1行目から最後までjson形式で出力した。しかしこのソースでは出力されるjsonの{}が[]になってしまうという問題も解決出来ておりません。

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

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Zuishin

    2020/05/23 15:19

    このくらいだったら Json.NET を使わなくても文字列操作だけでできそうですが、一度オブジェクトに変換するなら CsvHelper を使うことを検討してみてください。

    https://baba-s.hatenablog.com/entry/2018/05/17/090000

    キャンセル

  • hihijiji

    2020/05/23 17:41

    {"aaa": "1" ,"bbb": "2", "ccc": "3" }
    {"aaa": "50" ,"bbb": "70", "ccc": "90" }
    だとJSONになってませんからライブラリを使う方が面倒な気がします。

    キャンセル

回答 1

checkベストアンサー

+2

こんなのでいいですか?

using System;
using System.IO;
using System.Linq;
using System.Text;
using Newtonsoft.Json;

namespace CsvRead
{
    class Test
    {
        static void Main()
        {
            var sr = new StreamReader(@"test.csv", Encoding.GetEncoding("shift_jis"));
            {
                var keys = sr.ReadLine().Split(',');
                while(!sr.EndOfStream)
                {
                    var values = sr.ReadLine().Split(',');
                    var dic = keys.Zip(values, (k, v) => new { k, v }).ToDictionary(x => x.k, x => x.v);
                    Console.WriteLine(JsonConvert.SerializeObject(dic));
                }
            }
        }
    }
}

参考
.net - Map two lists into a dictionary in C# - Stack Overflow

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/05/25 08:38

    参考もとてもありがたいです。ご回答ありがとうございます。

    キャンセル

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

  • ただいまの回答率 89.25%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる