1、将一个数据集合导出到一个csv文件中,集合类型可以视为 List<T>,T为任意类型,T包含多个属性,可指定部分属性进行导出
2、软件中有多种不同类型的数据类型需要进行导出
需求很简单,简单分析下
1、csv格式就是文本格式,包含多行数据,每行包含多列文字,文字间已Tab标记分隔(简单,无需过多考虑)
2、针对数据类型T可以是任意类型,
3、支持指定属性导出,同一个类型也允许指定不同的属性组分别导出
4、属性与最终生成的文件中的列 一一对应,每个属性可以设置对应的列名称
1、指定需要导出的属性名称,通过反射获取对象的属性值
2、拼接为csv文本字符串
3、提供属性名称与列名称的一一对应关系
4、使用一个简单的导出csv工具类型,仅一个一个静态方法,接受List<T>类型数据集合,以List<Piar>方式传入ColumnName与PropertyName的键值对
5、写入某指定的csv文件
开发过程适当合理更改,如将文件写入逻辑移除(文件写入逻辑应在上层进行),保持导出逻辑简单,形成如下代码
假设类型定义如下
public class User { public string Name { get;set; } public string Info { get;set; } }
若存在一个用户列表List<User> Users{get;set;}
则生成csv格式字符串的代码如下
public string GenerateUserExportText() { return ExportCsvUtility.GenerateExportText(Usrs, new List<KeyValuePair<string, string>>() { new KeyValuePair<string, string>("用户名", "Name"), new KeyValuePair<string, string>("用户信息", "Info"), }); }
上层使用的选择保存文件 及 写入文件的方法可以参照我提供的下列代码:
注意StreamWriter的构造方法中,需传入参数设置Unicode编码,否则Excel打开csv文件会有问题
private bool TryGetOutFilePath(out string filePath) { SaveFileDialog saveFileDialog = new SaveFileDialog() { FileName = DateTime.Now.ToString("yyyy-MM-dd HH-mm-ss"), DefaultExt = ".text", Filter = "csv documents (.csv)|*.csv", }; if (saveFileDialog.ShowDialog() == true) { filePath = saveFileDialog.FileName; return true; } filePath = string.Empty; return false; } private void ExportToFile(string filePath, string fullText) { try { using (FileStream outFileStream = new FileStream(filePath, FileMode.Create, FileAccess.Write)) { using (TextWriter textWriter = new StreamWriter(outFileStream, Encoding.Unicode)) { textWriter.Write(fullText); } } } catch (Exception e) { ExceptionHandler.HandleException(e); } }
代码中使用的反射技巧,直接从我的其他项目中抽取了过来,后续可以专门做个介绍