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

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

ただいまの
回答率

90.61%

  • JSON

    1115questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • CSV

    602questions

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

  • Go

    481questions

    Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Go言語 JsonファイルをCSVに

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 471

yan-c

score 2

 前提・実現したいこと

前提

  • 初心者ウェブ系エンジニア
  • もともとPHPとか。Goは触って2weekほど

実現したいこと

  • GoでJsonファイルをCSVに変換したい
    -- Json読み込み
    -- 1行ずつ変数に(以下のサンプルコードには記述してないが、bufioを利用して1行ずつ読み込む想定))
    -- 構造体に合わせて、CSV出力
  • 可能であればCSVの区切りをタブにしたい(TSV)

 利用パッケージ

https://github.com/gocarina/gocsv
※他によいものがあればご教示いただけますと幸いです。

 参考サイト

https://qiita.com/nkumag/items/ef372ea35dcfbfa19310
※このサイトの場合外部ファイル読み込みではない

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

エラーメッセージ(例)
./test.go:28:28: cannot take the address of Client(test)
./test.go:28:35: cannot convert test (type os.File) to type Client
package main

import (
    "fmt"
    "os"

    "github.com/gocarina/gocsv"
)

type Client struct { // 構造体にcsvタグをつける、これがCSVに出力される際のタイトルになる
    Id   string `json:"id" csv:"id"`
    Name string `json:"name" csv:"名前"`
    Age  string `json:"age" csv:"年齢"`
}

func main() {
    filename := "test.csv"
    fp, err := os.Open(filename)
    if err != nil {
        // エラー処理
    }
    defer fp.Close()
    test := *fp

    clients := []*Client{}
    clients = append(clients, &Client{Id: "12", Name: "John", Age: "21"}) // Add clients
    clients = append(clients, &Client{Id: "13", Name: "Fred"})

        // {id: "1", Name: "test"}
    clients = append(clients, &Client(test))

    fmt.Println(test)
    fmt.Println("-")
    fmt.Println(clients)

    file, _ := os.OpenFile("sample.csv", os.O_RDWR|os.O_CREATE, os.ModePerm)
    defer file.Close()

    // csvファイルを書き出し
    gocsv.MarshalFile(&clients, file)

    // ファイルではなく文字書き出しをする場合
    // csvStr, err := gocsv.MarshalString(&clients)
}

 試したこと

スライスの箇所をいくつか記述を変更してみたのですが、
実現できず・・・・

初歩的なところかもしれませんが、ご回答いただけますと大変うれしいです。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • kawakawa2018

    2018/04/18 13:12

    一応「test.csv」のサンプルを追記してください。

    キャンセル

  • kawakawa2018

    2018/04/18 13:15

    すみません、「sample.csv」ですね。

    キャンセル

回答 1

+1

はじめまして
ソースを見た感じですと、Goの文法やプログラムの処理構造を
まだご理解させていないように思いました。

ですので動くコードを提示するのではなく、
アドバイス的なことを書きます。


エラーの原因

無関係の「test」変数を間違った処理しています。

ttps://github.com/gocarina/gocsv
のサンプルにありますが、

csvContent, err := gocsv.MarshalString(&clients)


に相当する処理が必要です。


まずですが、提示された
ttps://github.com/gocarina/gocsv

のサンプルをよくごらんになって仕組みを理解してみてください。

そして
・フォーマット変換処理 JSON形式からCSVの変換処理 
・ファイル処理 ファイル読み書き処理 

この2つを分けて作業し、それぞれを動く形にしてから
統合して完成させるといいです。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/04/18 22:26

    ありがとうございます!ちょっともろもろ確認致します。
    のちほどコメントを・・・

    キャンセル

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

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

関連した質問

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

  • JSON

    1115questions

    JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

  • CSV

    602questions

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

  • Go

    481questions

    Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。