前言

平常都是用 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. C#开发一个可被带参数调用并返回数据的控制台应用程序

    1 标准输出流控制台程序: namespace ReturnConsoleWrite { class Program { static void Main(string[] args) { //程序功 ...

  2. [oeasy]python0080_设置RGB颜色_24bit_24位真彩色_颜色设置

    RGB颜色 回忆上次内容 上次 首先了解了 索引颜色 \33[38;5;XXXm 设置 前景为索引色 \33[48;5;XXXm 设置 背景为索引色 RGB每种颜色 可选0-5 总共 6 级 想用 精 ...

  3. 题解:P10672 【MX-S1-T1】壁垒

    暑期集训=依托答辩. 分析 种类数是奇数一定无解. 否则每种数字先输出一次,在此过程中每增加两个数时,因为每个数字种类数都不一样,所以前缀种类数也同时增加 \(2\),保证一定为偶数. 然后输出完以后 ...

  4. ABC348

    A link 这道题就先输出整个的\(oox\),再输出剩一个两个的. 点击查看代码 #include<bits/stdc++.h> using namespace std; int n; ...

  5. GraphRAG介绍

    GraphRAG GraphRAG 是一种基于图的检索增强方法,由微软开发并开源.它通过结合LLM和图机器学习的技术,从非结构化的文本中提取结构化的数据,构建知识图谱,以支持问答.摘要等多种应用场景. ...

  6. 关于visual studio的一个bug

    本人初学链表,如有错误多多包涵 快马加鞭,这期只写一个问题.我好像在vs里面发现了一个bug 不管是vs2022还是vs2010都无法正常运行.关于cin.string.链表的问题 #include& ...

  7. JWT浅了解

    JWT通过数字签名的方式(让我想起了软考),以json对象为载体,在不同的服务终端之间安全传输信息 是一种授权认证 生成token的原理:通过header的加密方式,对payload进行加密.然后把h ...

  8. Codeforces Round 953 (Div. 2)

    Codeforces Round 953 (Div. 2) 闲来无事水题解. A . B . C 显然 \(k\) 是偶数.考虑 \(k\) 的上界,\(p_{1}=n,p_{n}=1\),产生 \( ...

  9. Linux 有趣命令

    代码雨 1.上传软件包 Linux 获取 wget https://jaist.dl.sourceforge.net/project/cmatrix/cmatrix/1.2a/cmatrix-1.2a ...

  10. 【MySQL】java.sql.SQLException: Illegal mix of collations (utf8mb4_0900_ai_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT) for operation '='

    问题原因参考: http://t.zoukankan.com/zhulei2-p-13451554.html collations 排序规则 Illegal mix 非法混合 SQL报错指出,操作符等 ...