golang 解析cvs檔案

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。//本程式是為了根據cvs的內容,自動生即時效果的報文,第七列為最後值
//用法: 程式名+檔案名稱
package main
import (
    "encoding/csv"
    "flag"
    "fmt"
    "io"
    "log"
    "os"
    "strings"
)
func main() {
    //參數
    flag.Parse()
    fmt.Println(flag.NArg())
    if flag.NArg() != 1 {
        log.Printf("usage: command + filename")
        return
    }
    //只取第1個參數做為檔案名稱
    file, err := os.Open(flag.Arg(0))
    if err != nil {
        fmt.Println("Error:", err)
        return
    }
    defer file.Close()
    reader := csv.NewReader(file)
    reader.Comment = '#' //可以設定讀入檔案中的注釋符
    reader.Comma = ',' //預設是逗號,也可以自己設定
    //還可以設定以下資訊
    //FieldsPerRecord  int  // Number of expected fields per record
    //LazyQuotes       bool // Allow lazy quotes
    //TrailingComma    bool // Allow trailing comma
    //TrimLeadingSpace bool // Trim leading space
    //line             int
    //column           int
    fout, err := os.OpenFile("out.txt", os.O_RDWR|os.O_APPEND|os.O_CREATE, 0666)
    if err != nil {
        fmt.Println("Error:", err)
        return
    }
    defer fout.Close()
    content := ""
    k := 0 //第一行是欄位名,不需要
    for {
        record, err := reader.Read()
        if err == io.EOF {
            break
        } else if err != nil {
            fmt.Println("Error:", err)
            return
        }
        if k > 0 { //record是[]strings, 怎樣直接獲得域值
            for _, v := range record {
                tmp := strings.Split(v, "|")
                //fmt.Print("<" + tmp[1] + ">" + tmp[7] + "</" + tmp[1] + ">")
                content = content + "<" + tmp[1] + ">" + tmp[7] + "</" + tmp[1] + ">"
            }
        }
        k = k + 1
    }
    fmt.Printf("\n")
    fout.WriteString(content + "\n")
    fmt.Printf("\n")
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.