分享
golang 解析cvs文件
zistxym · · 6756 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
//本程序是为了根据cvs的内容,自动生实时效果的报文,第七列为最后值
//用法:程序名+文件名
packagemain
import(
"encoding/csv"
"flag"
"fmt"
"io"
"log"
"os"
"strings"
)
funcmain(){
//参数
flag.Parse()
fmt.Println(flag.NArg())
ifflag.NArg() != 1 {
log.Printf("usage: command + filename")
return
}
//只取第1个参数做为文件名
file, err := os.Open(flag.Arg(0))
iferr != nil {
fmt.Println("Error:", err)
return
}
deferfile.Close()
reader := csv.NewReader(file)
reader.Comment = '#' //可以设置读入文件中的注释符
reader.Comma = ',' //默认是逗号,也可以自己设置
//还可以设置以下信息
//FieldsPerRecordint//Numberofexpectedfieldsperrecord
//LazyQuotesbool//Allowlazyquotes
//TrailingCommabool//Allowtrailingcomma
//TrimLeadingSpacebool//Trimleadingspace
//lineint
//columnint
fout, err := os.OpenFile("out.txt", os.O_RDWR|os.O_APPEND|os.O_CREATE, 0666)
iferr != nil {
fmt.Println("Error:", err)
return
}
deferfout.Close()
content := ""
k := 0 //第一行是字段名,不需要
for{
record, err := reader.Read()
iferr == io.EOF {
break
}elseiferr != nil {
fmt.Println("Error:", err)
return
}
ifk > 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")
}
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信6756 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
//用法:程序名+文件名
packagemain
import(
"encoding/csv"
"flag"
"fmt"
"io"
"log"
"os"
"strings"
)
funcmain(){
//参数
flag.Parse()
fmt.Println(flag.NArg())
ifflag.NArg() != 1 {
log.Printf("usage: command + filename")
return
}
//只取第1个参数做为文件名
file, err := os.Open(flag.Arg(0))
iferr != nil {
fmt.Println("Error:", err)
return
}
deferfile.Close()
reader := csv.NewReader(file)
reader.Comment = '#' //可以设置读入文件中的注释符
reader.Comma = ',' //默认是逗号,也可以自己设置
//还可以设置以下信息
//FieldsPerRecordint//Numberofexpectedfieldsperrecord
//LazyQuotesbool//Allowlazyquotes
//TrailingCommabool//Allowtrailingcomma
//TrimLeadingSpacebool//Trimleadingspace
//lineint
//columnint
fout, err := os.OpenFile("out.txt", os.O_RDWR|os.O_APPEND|os.O_CREATE, 0666)
iferr != nil {
fmt.Println("Error:", err)
return
}
deferfout.Close()
content := ""
k := 0 //第一行是字段名,不需要
for{
record, err := reader.Read()
iferr == io.EOF {
break
}elseiferr != nil {
fmt.Println("Error:", err)
return
}
ifk > 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")
}