gpt4 book ai didi

c# - 需要帮助将列表传递给此 csv 导出类

转载 作者:行者123 更新时间:2023-11-30 14:38:32 29 4
gpt4 key购买 nike

我在网上找到了这个 CSV 导出类,想从另一个类传递我自己的列表我的列表已经准备好了,包含 3 列

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlTypes;
using System.IO;
using System.Reflection;


public class CsvExport<T> where T : class
{
public List<T> Objects;

public CsvExport(List<T> objects)
{
Objects = objects;
}

public string Export()
{
return Export(true);
}

public string Export(bool includeHeaderLine)
{

StringBuilder sb = new StringBuilder();
//Get properties using reflection.
IList<PropertyInfo> propertyInfos = typeof(T).GetProperties();

if (includeHeaderLine)
{
//add header line.
foreach (PropertyInfo propertyInfo in propertyInfos)
{
sb.Append(propertyInfo.Name).Append(",");
}
sb.Remove(sb.Length - 1, 1).AppendLine();
}

//add value for each property.
foreach (T obj in Objects)
{
foreach (PropertyInfo propertyInfo in propertyInfos)
{
sb.Append(MakeValueCsvFriendly(propertyInfo.GetValue(obj, null))).Append(",");
}
sb.Remove(sb.Length - 1, 1).AppendLine();
}

return sb.ToString();
}

//export to a file.
public void ExportToFile(string path)
{
File.WriteAllText(path, Export());
}

//export as binary data.
public byte[] ExportToBytes()
{
return Encoding.UTF8.GetBytes(Export());
}

//get the csv value for field.
private string MakeValueCsvFriendly(object value)
{
if (value == null) return "";
if (value is Nullable && ((INullable)value).IsNull) return "";

if (value is DateTime)
{
if (((DateTime)value).TimeOfDay.TotalSeconds == 0)
return ((DateTime)value).ToString("yyyy-MM-dd");
return ((DateTime)value).ToString("yyyy-MM-dd HH:mm:ss");
}
string output = value.ToString();

if (output.Contains(",") || output.Contains("\""))
output = '"' + output.Replace("\"", "\"\"") + '"';

return output;

}
}

最佳答案

如果你需要帮助使用这个类,那么我会说你需要做这样的事情。

为您的数据创建一个类..

public class MyData
{
public string Column1Data {get;set;}
public string Column2Data {get;set;}
public string Column3Data {get;set;}
}

像这样将 MyData 类型的列表传递到您的 CsvExport 类中...

List<MyData> list = new List<MyData>();
//populate the list here
CsvExport<MyData> export = new CsvExport<MyData>();
export.ExportToFile(@"C:\MyExportFile.txt");

你现在应该有一个像...这样的输出文件

Column1Data,Column2Data,Column3Data 
r1c1,r1c2,r1c3
r2c1,r2c2,r2c3
r3c1,r1c2,r3c3

要使用不同的输入类,只需将 MyData 引用切换为您所称的类即可

关于c# - 需要帮助将列表传递给此 csv 导出类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7836565/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com