亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

csv 轉換與 go

csv 轉換與 go

Go
慕勒3428872 2022-08-15 19:14:59
我仍然是golang的菜鳥,但我會嘗試解釋我想創造什么。我有這個:我想將同一個表轉換為csv文件,例如這是我的代碼:func maakCSVBestand() {    rapportage := haalRapportage()    opdrachten := rapportage.Opdrachten    csvFile, err := os.Create("Rapportage Urenverantwoording.csv")    if err != nil {        fmt.Println(err)    }    defer csvFile.Close()    writer := csv.NewWriter(csvFile)    writer.Comma = ';'    writer.Write([]string{"Datum", "Naam", "Aantal uren gewerkt", "Aantal deuren gemaakt", "Informatie"})    for i := 0; i < len(opdrachten); i++ {        var row []string        persoon := opdrachten[i].Persoon        row = append(row, opdrachten[i].Datum.String())        for j := 0; j < len(persoon); j++ {            row = append(row, persoon[j].Naam+" "+persoon[j].Achternaam)            row = append(row, strconv.FormatFloat(persoon[j].UrenGewerkt, 'g', 2, 64))            row = append(row, strconv.Itoa(persoon[j].AantalDeurenGemaakt))            row = append(row, persoon[j].Informatie)        }        writer.Write(row)    }    writer.Flush()}但這會產生我做錯了什么?
查看完整描述

1 回答

?
叮當貓咪

TA貢獻1776條經驗 獲得超12個贊

為內部循環的每次迭代寫入一行。清除第一次迭代后的第一列:


for i := 0; i < len(opdrachten); i++ {


    var row []string

    persoon := opdrachten[i].Persoon

    row = append(row, opdrachten[i].Datum.String())

    for j := 0; j < len(persoon); j++ {

        row = append(row, persoon[j].Naam+" "+persoon[j].Achternaam)

        row = append(row, strconv.FormatFloat(persoon[j].UrenGewerkt, 'g', 2, 64))

        row = append(row, strconv.Itoa(persoon[j].AantalDeurenGemaakt))

        row = append(row, persoon[j].Informatie)

        writer.Write(row)

        row[0] = ""   // clear Datum field

        row = row[1:] // collect new values after blank datum 

    }

}


查看完整回答
反對 回復 2022-08-15
  • 1 回答
  • 0 關注
  • 142 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號