前言

平常都是用 Excel 的多, 但这一次遇到 Google Ads. 谷歌嘛, 当然不喜欢微软的 Excel.

硬是要求 CSV. 没办法, 只能找 Library 搞一搞了.

参考

Docs – Getting Started

介绍

CsvHelper 只能简单的读写 CSV file, 接口也很少. 它最好的使用方式是一个 CSV file 对应一个 List<Item>.

它甚至不能像 Excel 那样, 选择某个 cell 直接修改. 只能 replace all.

安装

dotnet add package CsvHelper

Read CSV

首先定义 DataClass

和 Mapping logic

public class OfflineConversionData
{
// format refer: https://support.google.com/google-ads/answer/7014069#prepare_data
public string GoogleClickId { get; set; } = "";
public string ConversionName { get; set; } = "";
public string ConversionTime { get; set; } = "";
public decimal ConversionValue { get; set; }
public string ConversionCurrency { get; set; } = "";
}
public sealed class OfflineConversionDataMap : ClassMap<OfflineConversionData>
{
public OfflineConversionDataMap()
{
Map(e => e.GoogleClickId).Name("Google Click ID").Index(0);
Map(e => e.ConversionName).Name("Conversion Name").Index(1);
Map(e => e.ConversionTime).Name("Conversion Time").Index(2);
Map(e => e.ConversionValue).Name("Conversion Value").Index(3);
Map(e => e.ConversionCurrency).Name("Conversion Currency").Index(4);
}
}

然后

var rootPath = webHostEnvironment.WebRootPath;
var csvFilePath = Path.Combine(rootPath, "google-offline-conversion.csv");
using var streamReader = new StreamReader(csvFilePath);
using var csvReader = new CsvReader(streamReader, CultureInfo.InvariantCulture);
csvReader.Context.RegisterClassMap<OfflineConversionDataMap>();
var datas = csvReader.GetRecords<OfflineConversionData>();

read to DataTable

var rootPath = webHostEnvironment.WebRootPath;
var csvFilePath = Path.Combine(rootPath, "google-offline-conversion.csv");
using var streamReader = new StreamReader(csvFilePath);
using var csvReader = new CsvReader(streamReader, CultureInfo.InvariantCulture);
using var dataReader = new CsvDataReader(csvReader);
var table = new DataTable();
table.Load(dataReader);
var value = table.Rows[0][0].ToString(); // data only no header

Write CSV

using var memoryStream = new MemoryStream();
using var streamWriter = new StreamWriter(memoryStream);
using var csvWriter = new CsvWriter(streamWriter, CultureInfo.InvariantCulture);
csvWriter.Context.RegisterClassMap<OfflineConversionDataMap>(); var conversionDatas = new List<OfflineConversionData> {
new OfflineConversionData {
GoogleClickId = "EAIaIQobChMI9dfq693m_QIVRAQrCh3XcAANEAAYAyAAEgJJgPD_BwE",
ConversionName = "Test Offline Conversion",
ConversionTime = "2023-03-19 08:28:41 America/Los_Angeles",
ConversionValue = 230,
ConversionCurrency = "SGD",
},
new OfflineConversionData {
GoogleClickId = "CjwKCAjwq-WgBhBMEiwAzKSH6C7RiEiGFcxvUAr6GEMhGPcYyWSOSo5eiiD_rzedifklbBVhKO4fVBoCUH8QAvD_BwE",
ConversionName = "Test Offline Conversion",
ConversionTime = "2023-03-22 11:09:01 Asia/Singapore",
ConversionValue = 250,
ConversionCurrency = "SGD",
}
};
await csvWriter.WriteRecordsAsync<OfflineConversionData>(conversionDatas);
await csvWriter.FlushAsync(); var rootPath = webHostEnvironment.WebRootPath;
var csvFilePath = Path.Combine(rootPath, "google-offline-conversion.csv");
using var fileStream = System.IO.File.Create(csvFilePath);
await fileStream.WriteAsync(memoryStream.ToArray());
await fileStream.FlushAsync();

其它写入

csvWriter.WriteField("Hello World"); // first cell
csvWriter.NextRecord(); // next row
csvWriter.WriteField("Hello World 2"); // first cell

ASP.NET Core Library – CsvHelper的更多相关文章

  1. 《ASP.NET Core 高性能系列》致敬伟大的.NET斗士甲骨文!

    写在开始 三年前,曾写过一篇文章:从.NET和Java之争谈IT这个行业,当时遭到某些自认为懂得java就了不起的Javaer抨击, 现在可以致敬伟大的.NET斗士甲骨文了 (JDK8以上都需要收费, ...

  2. ASP.NET CORE MVC 2.0 项目中引用第三方DLL报错的解决办法 - InvalidOperationException: Cannot find compilation library location for package

    目前在学习ASP.NET CORE MVC中,今天看到微软在ASP.NET CORE MVC 2.0中又恢复了允许开发人员引用第三方DLL程序集的功能,感到甚是高兴!于是我急忙写了个Demo想试试,我 ...

  3. 基于 ASP.NET Core 2.1 的 Razor Class Library 实现自定义错误页面的公用类库

    注意:文中使用的是 razor pages ,建议使用 razor views ,使用 razor pages 有一个小坑,razor pages 会用到 {page} 路由参数,如果应用中也用到了这 ...

  4. ASP.NET Core and .NET Core Library Support

    ASP.NET Core and .NET Core Library Support 详情参见:https://github.com/linezero/NETCoreLibrary/blob/mast ...

  5. ASP.NET Core 1.0 开发记录

    官方资料: https://github.com/dotnet/core https://docs.microsoft.com/en-us/aspnet/core https://docs.micro ...

  6. ASP.NET Core: You must add a reference to assembly mscorlib, version=4.0.0.0

    ASP.NET Core 引用外部程序包的时候,有时会出现下面的错误: The type 'Object' is defined in an assembly that is not referenc ...

  7. ASP.NET Core中的依赖注入(1):控制反转(IoC)

    ASP.NET Core在启动以及后续针对每个请求的处理过程中的各个环节都需要相应的组件提供相应的服务,为了方便对这些组件进行定制,ASP.NET通过定义接口的方式对它们进行了"标准化&qu ...

  8. ASP.NET Core 1.0中实现文件上传的两种方式(提交表单和采用AJAX)

    Bipin Joshi (http://www.binaryintellect.net/articles/f1cee257-378a-42c1-9f2f-075a3aed1d98.aspx) Uplo ...

  9. Asp.Net Core 项目实战之权限管理系统(3) 通过EntityFramework Core使用PostgreSQL

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  10. 来份ASP.NET Core尝尝

    0x01.前言 学习ASP.NET Core也有一段时间了,虽说很多内容知识点还是处于一知半解的状态,但是基本的,还是 略懂一二.如果有错误,还望见谅. 本文还是和之前一样,Demo+在Linux下运 ...

随机推荐

  1. 国内版Unity 2023编辑器无法切换到DX12模式的解决方法

    2024.7.4更新:至6000.0.5f1c1,此问题已修复 在{安装目录}\Editor里(也就是Unity安装的根目录)建立一个名叫D3D12的文件夹. 去{安装目录}\Editor\Data\ ...

  2. oeasy教您玩转vim - 14 - # 行头行尾

    行头行尾 回忆上节课内容 我们这次了解了 大词 和 小词 小词 就是我们常规意义的词 被 =." 等标点分开的词 大词 里面包括了 =." 等标点 只能被空格.tab.换行分割 W ...

  3. C# Winform与JS交互

    一.C#调用JS函数 1.JS代码 < script language = "javascript" > function Hello(msg) { alert('我是 ...

  4. 买卖股票相关算法-动态规划-python

    要求1: 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格. 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票.设计 ...

  5. h5py文件写入之——flush和update

    技术背景 在前面的一篇博客中,我们介绍过使用VMD可视化H5MD标准化格式的轨迹文件的方法.H5MD本质上就是一个有规范格式的hdf5二进制文件,本文主要介绍两个关于hdf5的内容更新操作. 写入和更 ...

  6. python __del__() 清空对象

    python __del__() 清空对象 python垃圾回收机制:当一个对象的引用被完全清空之后,就会调用__del__()方法来清空这个对象 当对象的引用没有被完全清空时,代码如下: class ...

  7. python对象之间的交互

    python对象之间的交互 先看看一般的类定义如下: class 类名: def __init__(self,参数1,参数2): self.对象的属性1 = 参数1 self.对象的属性2 = 参数2 ...

  8. LinuxUDP通讯

    目录 前言 一.UDP通讯 1.UDP通讯概述 2.UDP的特点 3.UDP的应用 二.UDP基本通讯 1.socket函数 2.bind函数 2.1 主机字节序和网络字节序 2.2 点分制十进制转换 ...

  9. 【PHP】5版本 过程式操作MySQL

    建立连接和释放连接: # 连接参数 $sever = 'localhost:3309'; $username = 'root'; $password = 'root'; # 调用连接方法,如果失败结束 ...

  10. 【Java】JDBC Part1 数据库连接的演变

    环境搭建 使用Maven工程的依赖项,如果普通工程就点注释的地址下载jar包即可 <dependencies> <!-- https://mvnrepository.com/arti ...