export datatable to csv
时间:2021-09-09
本文章向大家介绍export datatable to csv,主要包括export datatable to csv使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
export datatable to csv
You could go through the rows and columns like this.
void Main()
{
var dt = new DataTable();
dt.Columns.Add("Id", typeof(int));
dt.Columns.Add("Name", typeof(string));
var row = dt.NewRow();
row["Id"] = 1;
row["Name"] = "one";
dt.Rows.Add(row);
row = dt.NewRow();
row["Id"] = 2;
row["Name"] = "two";
dt.Rows.Add(row);
using (var writer = new StringWriter())
using (var csv = new CsvWriter(writer, CultureInfo.InvariantCulture))
{
foreach (DataColumn dc in dt.Columns)
{
csv.WriteField(dc.ColumnName);
}
csv.NextRecord();
foreach (DataRow dr in dt.Rows)
{
foreach (DataColumn dc in dt.Columns)
{
csv.WriteField(dr[dc]);
}
csv.NextRecord();
}
writer.ToString().Dump();
}
}
Or you could use a DataReader
and to it like this.
void Main()
{
var dt = new DataTable();
dt.Columns.Add("Id", typeof(int));
dt.Columns.Add("Name", typeof(string));
var row = dt.NewRow();
row["Id"] = 1;
row["Name"] = "one";
dt.Rows.Add(row);
row = dt.NewRow();
row["Id"] = 2;
row["Name"] = "two";
dt.Rows.Add(row);
using (var writer = new StringWriter())
using (var csv = new CsvWriter(writer, CultureInfo.InvariantCulture))
{
using (var reader = dt.CreateDataReader())
{
for (var i = 0; i < reader.FieldCount; i++)
{
csv.WriteField(reader.GetName(i));
}
csv.NextRecord();
while (reader.Read())
{
csv.WriteField(reader.GetFieldValue<int>("Id"));
csv.WriteField(reader.GetFieldValue<string>("Name"));
csv.NextRecord();
}
}
writer.ToString().Dump();
}
}
If there are better ways, let me know. I'm not too familiar with data tables.
datatable转换为csv对应的字节流
public static byte[] DataTableToCsvBytes(DataTable dt) { if (null == dt) return Array.Empty<byte>(); using (var memory = new MemoryStream()) { using (var writer = new StreamWriter(memory)) { var config = new CsvConfiguration(CultureInfo.InvariantCulture); config.SanitizeForInjection = true; config.InjectionEscapeCharacter = '\''; using (var csv = new CsvWriter(writer, config)) { foreach (DataColumn dc in dt.Columns) { csv.WriteField(dc.ColumnName); } csv.NextRecord(); foreach (DataRow dr in dt.Rows) { foreach (DataColumn dc in dt.Columns) { csv.WriteField(dr[dc]); } csv.NextRecord(); } writer.Flush(); } } return memory.ToArray(); } }
原文地址:https://www.cnblogs.com/chucklu/p/15246306.html
- Leetcode-Easy 136. Single Number
- 2017.10.25水题大作战题解
- Angular开发实践(四):组件之间的交互
- Leetcode-Easy 70. Climbing Stairs
- Angular开发实践(八): 使用ng-content进行组件内容投射
- Angular开发实践(六):服务端渲染
- Leetcode-Easy 657. Judge Route Circle
- 洛谷P1138 第k小整数
- Leetcode-Easy 796. Rotate String
- 2017.10.23解题报告
- Leetcode-Easy 461.Hamming Distance
- 洛谷P1439 最长公共子序列(LCS问题)
- Leetcode-Easy 575. Distribute Candies
- 洛谷P2115 [USACO14MAR]破坏Sabotage
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- RPC 和 REST还有RESTFul到底是个什么玩意?
- 线程和线程池的几个状态值
- 阿里代码规约为什么不让使用Executors包装好线程池呢?
- Groovy、热部署和热加载(自定义类加载器)及spring loaded 部分源码分析
- Centos在线迁移到腾讯云cvm
- ClickHouse源码导读:网络IO
- 手把手教你:将ClickHouse集群迁至云上
- 直播中台iLiveSDK终端框架演变之路
- ClickHouse 数据导入实战:Kafka 篇
- pipeAsyncFunctions
- 【python-leetcode287-循环排序】寻找重复的数
- 聊聊claudb的list command
- 【python-leetcode448-循环排序】找到所有数组中消失的数字
- input/change/composition/keydown事件详解
- isSameDate