Golang csv操作
csv读写
封装成工具包
package utils
import (
"encoding/csv"
"fmt"
"log"
"os"
"path"
"time"
)
func ReadCsv(filePath string) (data [][]string, err error) {
f, err := os.Open(filePath)
if err != nil{
fmt.Println(err)
return
}
defer f.Close()
w := csv.NewReader(f)
data, err = w.ReadAll()
if err != nil{
fmt.Println(err)
return
}
//fmt.Println(data)
return data,nil
}
/*
filename := "shodan-port-all" 文件名,不要后缀
columns := [][]string{{"姓名", "电话", "公司", "职位", "加入时间"}, {"1", "2", "刘犇,刘犇,刘犇", "4", "5"}}
utils.ExportCsv("log/", "shodan-port", columns) 会存到log/shodan-port-2021-09-07 23:23:14.csv里
*/
func ExportCsv(savePath, fileName string, data [][]string) {
fmt.Println("data22222",data)
filePath := fmt.Sprintf("%s-%s.csv",fileName,time.Now().Format("2006-01-02"))
floder := "./"
if len(savePath) >= 0 {
floder = path.Join(floder, savePath)
}
if _, err := os.Stat(floder); err != nil {
if !os.IsExist(err) {
os.MkdirAll(floder, os.ModePerm)
}
}
fp, err := os.Create(path.Join(floder,filePath)) // 创建文件句柄
if err != nil {
log.Fatalf("创建文件["+filePath+"]句柄失败,%v", err)
return
}
defer fp.Close()
fp.WriteString("\xEF\xBB\xBF") // 写入UTF-8 BOM
w := csv.NewWriter(fp) //创建一个新的写入文件流
w.WriteAll(data)
w.Flush()
}
原文链接:https://blog.csdn.net/ljrsunshine/article/details/100107705
追加写入
Golang
判断文件是否存在:如果文件不存在,那么创建文件,并写入csv的标题字段和第一条数据;如果文件存在,追加写一条数据
需求
- 给定一个以@为分隔符的字符串,分隔了4条信息,还需要再加上时间戳信息,然后按照特定的顺序写入csv中
笔者因为任务需要,在windows和linux系统中都运行了一遍代码,发现在追加写操作时: - 在windows系统中,代码 txt, err := os.OpenFile(csvName, os.O_APPEND, 0666) 运行无误
- 而在linux系统中,必须添加 os.O_RDWR(以读写的方式打开) 才能追加写成功,代码为 os.OpenFile(csvName, os.O_APPEND|os.O_RDWR, 0666)
- 给定一个以@为分隔符的字符串,分隔了4条信息,还需要再加上时间戳信息,然后按照特定的顺序写入csv中
笔者刚开始接触Go语言,若有代码结构和语法不规范的地方,请多包涵!
代码
package main
import (
"encoding/csv"
"fmt"
"os"
"strings"
"time"
)
func main() {
m3u8_dir_path := "13429235688@01@05@09"
data := strings.Split(m3u8_dir_path, "@")
//需要在index=1的地方插入时间戳,方便以“id time emo val arou”的顺序写入csv文件
//将index=1后面的数据保存到一个临时的切片(其实是对index后面数据的复制)
tmp := append([]string{}, data[1:]...)
//拼接插入的时间戳
data = append(data[0:1], time.Now().Format("20060102150405"))
//与临时切片再组合得到最终的需要的切片
data = append(data, tmp...)
fmt.Printf("data[0]: %s\n", data[0])
fmt.Printf("data[1]: %s\n", data[1])
fmt.Printf("data[2]: %s\n", data[2])
fmt.Printf("data[3]: %s\n", data[3])
fmt.Printf("data[4]: %s\n", data[4])
csvName := data[0] + ".csv"
file, er := os.Open(csvName)
defer file.Close()
// 如果文件不存在,创建文件
if er != nil && os.IsNotExist(er) {
file, er := os.Create(csvName)
if er != nil {
panic(er)
}
defer file.Close()
// 写入字段标题
w := csv.NewWriter(file) //创建一个新的写入文件流
title := []string{"user_id", "time", "emo", "val", "arou"}
// 这里必须刷新,才能将数据写入文件。
w.Write(title)
w.Write(data)
w.Flush()
fmt.Printf("if end")
} else {
// 如果文件存在,直接加在末尾
txt, err := os.OpenFile(csvName, os.O_APPEND|os.O_RDWR, 0666)
defer txt.Close()
if err != nil {
panic(err)
}
w := csv.NewWriter(txt) //创建一个新的写入文件流
w.Write(data)
w.Flush()
fmt.Printf("else end")
}
}
追加写入封装
func FileExists(filename string) bool {
info, err := os.Stat(filename)
if os.IsNotExist(err) {
return false
}
if info == nil {
return false
}
return true
}
/*
文件没有创建并写入,有追加写
filename := "/Users/icsoc/Downloads/test.csv"
columns := [][]string{{"姓名", "电话", "公司", "职位", "加入时间"}, {"1", "2", "刘犇,刘犇,刘犇", "4", "5"}}
utils.ExportCsvWithAdd("log/", "shodan-port", columns) 会存到static/downloads.csv里
*/
func ExportCsvWithAdd(savePath, fileName string, data [][]string) (fPath string) {
fileNamePath := fmt.Sprintf("%s.csv", fileName)
floder := "./"
if len(savePath) >= 0 {
floder = filepath.Join(floder, savePath)
}
// 创建文件夹
if _, err := os.Stat(floder); err != nil {
if !os.IsExist(err) {
os.MkdirAll(floder, os.ModePerm)
}
}
fPath = filepath.Join("./", floder, fileNamePath)
if !FileExists(fPath) {
fp, err := os.Create(fPath) // 创建文件句柄
if err != nil {
log.Fatalf("创建文件["+fileNamePath+"]句柄失败,%v", err)
return
}
defer fp.Close()
fp.WriteString("\xEF\xBB\xBF") // 写入UTF-8 BOM
w := csv.NewWriter(fp) //创建一个新的写入文件流
w.WriteAll(data)
w.Flush()
} else {
// 如果文件存在,直接加在末尾
txt, err := os.OpenFile(fPath, os.O_APPEND|os.O_RDWR, 0666)
defer txt.Close()
if err != nil {
log.Printf("os.OpenFile fail , fPath:%v", fPath)
return
}
w := csv.NewWriter(txt) //创建一个新的写入文件流
w.WriteAll(data)
w.Flush()
}
return fPath
}
Golang csv操作的更多相关文章
- Java CSV操作(导出和导入)
Java CSV操作(导出和导入) CSV是逗号分隔文件(Comma Separated Values)的首字母英文缩写,是一种用来存储数据的纯文本格式,通常用于电子表格或数据库软件.在 CSV文件 ...
- csv操作帮助类
功能描述: 集合转换为csv数据 DataSe转换为csv数据 using System; using System.Collections.Generic; using System.Data; u ...
- 【Java】Java CSV操作代码
CSV是逗号分隔文件(Comma Separated Values)的首字母英文缩写,是一种用来存储数据的纯文本格式,通常用于电子表格或数据库软件.在 CSV文件中,数据“栏”以逗号分隔,可允许程序通 ...
- python之pandas数据筛选和csv操作
本博主要总结DaraFrame数据筛选方法(loc,iloc,ix,at,iat),并以操作csv文件为例进行说明 1. 数据筛选 a b c (1)单条件筛选 df[df[] # 如果想筛选a列的取 ...
- pandas 写csv 操作
pandas 写csv 操作 def show_history(self): df = pd.DataFrame() df['Time'] = pd.Series(self.time_hist) df ...
- golang csv问题
go语言自带的有csv文件读取模块,看起来好像不错,今天玩玩,也算是系统学习go语言的一部分--^_^ 一.写csv文件 函数: func NewWriter(w io.Writer) *Writer ...
- Golang 中操作 Mongo Update 的方法
Golang 和 MongoDB 中的 ISODate 时间交互问题 2018年02月27日 11:28:43 独一无二的小个性 阅读数:357 标签: GolangMongoDB时间交互时间转换 更 ...
- python之csv操作
在使用python爬虫时或者其他情况,都会用到csv存储与读取的相关操作,我们在这里就浅谈一下: CSV(Comma-Separated Values)逗号分隔符,也就是每条记录中的值与值之间是用分号 ...
- Golang文件操作整理
基本操作 文件创建 创建文件的时候,一定要注意权限问题,一般默认的文件权限是 0666 关于权限的相关内容,具体可以参考鸟叔p141 这里还是再回顾下,文件属性 r w x r w x r w x,第 ...
- golang数据库操作初体验
在golang中,提供了标准的数据库接口database/sql包,做过数据库开发的应该知道,不同的数据库有不同的数据库驱动.比如mysql等,我们可以去找 https://golang.org/s/ ...
随机推荐
- UEFI引导双系统安装archlinux后安装windows8.1,os-prober无法探测,生成grub.cfg没有windows
1.os-prober无法探测 可能是os-prober未启用 启用os-prober: sudo vim /etc/default/grub 添加: GRUB_DISABLE_OS_PROBER=f ...
- CH395的FTP Server(主动模式)简单应用参考
FTP(File Transfer Protocol,文件传输协议) 是 TCP/IP 协议组中的协议之一.FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端.本篇文章将基于FTP协议 ...
- 10 JavaScrit定时器
10 JavaScrit定时器 在JS中, 有两种设置定时器的方案: // 语法规则 t = setTimeout(函数, 时间) // 经过xxx时间后, 执行xxx函数 // 5秒后打印我爱你 t ...
- 1开幕在即 | “万物互联,使能千行百业”2022开放原子全球开源峰会OpenAtom OpenHarmony分论坛
7月27日下午,聚焦开源产业与生态的2022开放原子全球开源峰会OpenAtom OpenHarmony分论坛将在北京亦创国际会展中心盛大开幕. 作为OpenHarmony工作委员会联合生态合作伙伴为 ...
- 一种基于DeltaE(CIE 1976)的找色算法Cuda实现
书接上文 一种基于DeltaE(CIE 1976)的找色算法 Delta E 是评估色彩准确度的重要测量指标.摄影师.影片编辑和平面设计师等创意专业人士都应重视这项标准,因其是选择专业级显示器的重要考 ...
- std::thread 三:条件变量(condition_variable())
condition_variable . wait . notify_one . notify_all *:notify_one:通知(唤醒)一个线程 *:notify_all:通知( ...
- DevEco Studio 3.1 Beta新特性知多少
原文链接:https://mp.weixin.qq.com/s/HYdNlKKA9Z51dfI1bcplDA,点击链接查看更多技术内容: DevEco Studio 3.1 Beta新特性知多少原文 ...
- windows下redis主从配置
1,复制两个redis文件夹,粘贴在同级目录下 2,分别修改6380和6381文件夹中的redis.window.conf文件 port:分别改为6380.6381 均增加:slaveof 127.0 ...
- em/px/rem/vh/vw的区别
一.介绍 传统的项目开发中,我们只会用到px.%.em这几个单位,它可以适用于大部分的项目开发,且拥有比较良好的兼容性 从CSS3开始,浏览器对计量单位的支持又提升到了另外一个境界,新增了rem.vh ...
- Asp-Net-Core开发笔记:使用alpine镜像并加入健康检查
前言 使用 docker 部署 AspNetCore 应用已经是标配了,之前我一直使用 mcr.microsoft.com/dotnet/aspnet:8.0 这类镜像,简单粗暴,不过可以使用 alp ...