分享
  1. 首页
  2. 文章

Golang为别人写的csv文件处理的例子

fyxichen · · 4753 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

package main
import (
 "encoding/csv"
 "flag"
 "io"
 "log"
 "os"
 "sort"
 "strings"
)
var quick, first, unrepeat bool
func main() {
 path := flag.String("p", "", "-p 指定csv文件路径")
 logname := flag.String("l", "", "-l 指定结果输出路径,不指定则输出到标准输出")
 flag.BoolVar(&quick, "q", false, "-q 数据全部加载到内存中处理,默认是少量数据加载到内存操作,bool值")
 flag.BoolVar(&first, "f", false, "-f 使用首次遇到的一条数据,默认是使用最后遇到的一条数据,bool值")
 flag.BoolVar(&unrepeat, "u", false, "-u 默认是使用重复数据,bool值")
 flag.Parse()
 if *logname != "" {
 File, err := os.Create(*logname)
 if err != nil {
 log.Println("创建输出文件失败:", err.Error())
 return
 }
 log.SetOutput(File)
 }
 if *path == "" {
 flag.Usage()
 return
 }
 Read(*path)
}
func Read(path string) {
 File, err := os.Open(path)
 if err != nil {
 log.Println("读取csv文件失败,错误信息:", err.Error())
 return
 }
 defer File.Close()
 csvr := csv.NewReader(File)
 if quick {
 QMerge(csvr)
 } else {
 list := SMerge(csvr, File)
 FromLineRead(list, path)
 }
}
func QMerge(r *csv.Reader) {
 var m = make(map[string][]string)
 var list []string
 var repeat []string
 r.Read()
 var err error
 var key string
 for {
 list, err = r.Read()
 if err != nil {
 if err != io.EOF {
 log.Println("读取文件内容失败,错误信息:", err.Error())
 }
 break
 }
 if len(list) != 5 {
 log.Println("无效数据:", list)
 continue
 }
 key = strings.TrimSpace(list[1] + list[3])
 if key != "" {
 if _, ok := m[key]; ok {
 repeat = append(repeat, key)
 if !first {
 m[key] = list
 }
 } else {
 m[key] = list
 }
 }
 }
 for _, value := range repeat {
 if unrepeat {
 delete(m, value)
 } else {
 log.Println(m[value])
 }
 }
 if unrepeat {
 for _, value := range m {
 log.Println(value)
 }
 }
}
func SMerge(r *csv.Reader, seek io.Seeker) []int {
 var m = make(map[string]int)
 var list []string
 var repeat []string
 r.Read()
 var key string
 var err error
 var line int
 for {
 list, err = r.Read()
 if err != nil {
 if err != io.EOF {
 log.Println("读取文件内容失败,错误信息:", err.Error())
 }
 break
 }
 if len(list) != 5 {
 log.Println("无效数据:", list)
 line++
 continue
 }
 key = strings.TrimSpace(list[1] + list[3])
 if key != "" {
 if _, ok := m[key]; ok {
 repeat = append(repeat, key)
 if !first {
 m[key] = line
 }
 } else {
 m[key] = line
 }
 }
 line++
 }
 var lines = make([]int, 0, len(m))
 for _, v := range repeat {
 if unrepeat {
 delete(m, v)
 } else {
 lines = append(lines, m[v])
 }
 }
 if unrepeat {
 for _, v := range m {
 lines = append(lines, v)
 }
 }
 sort.Ints(lines)
 return lines
}
func FromLineRead(lines []int, path string) {
 File, err := os.Open(path)
 if err != nil {
 log.Println("读取csv文件失败:", err.Error())
 return
 }
 defer File.Close()
 r := csv.NewReader(File)
 r.Read()
 var list []string
 var line, index int
 for {
 list, err = r.Read()
 if err != nil {
 if err != io.EOF {
 log.Println("读取文件内容失败,错误信息:", err.Error())
 }
 break
 }
 if lines[index] == line {
 log.Println(list)
 index++
 if index >= len(lines) {
 break
 }
 }
 line++
 }
}

有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:fyxichen

查看原文:Golang为别人写的csv文件处理的例子

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
4753 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏