首页 > 代码库 > C# Datatable导出CSV算法
C# Datatable导出CSV算法
/// <summary>
/// 导出数据到CSV文件
/// </summary>
/// <param name="dtExportTable">需要导出的datatable</param>
/// <param name="dicColumnsInfo">导出的列字典,key datable中的列,value需要导出的列名称</param>
/// <param name="FilePath">导出的文件路径</param>
public static void ExportCSV(DataTable dtExportTable, Dictionary<string, string> dicColumnsInfo,string FilePath)
{
List<string> notExist=new List<string>();
if(dtExportTable!=null&&dicColumnsInfo!=null)
{
foreach(string key in dicColumnsInfo.Keys)
{
if(!dtExportTable.Columns.Contains(key))
{
notExist.Add(key);
}
}
}
foreach(string key in notExist)
{
dicColumnsInfo.Remove(key);
}
for(int i=dtExportTable.Columns.Count-1;i>=0;i--)
{
string colName=dtExportTable.Columns[i].ColumnName;
if(!dicColumnsInfo.ContainsKey(colName))
{
dtExportTable.Columns.RemoveAt(i);
}
}
if (dtExportTable == null || dtExportTable.Columns.Count <= 0 || dtExportTable.Rows.Count <= 0 || dicColumnsInfo == null || dicColumnsInfo.Count <= 0 || string.IsNullOrEmpty(FilePath))
throw new Exception("导出条件不满足!");
StringBuilder sbResult=new StringBuilder();
int ColCount=dtExportTable.Columns.Count;
string Header=string.Empty;
for(int i=0;i<ColCount;i++)
{
if(String.IsNullOrEmpty(Header))
{
Header = dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
}
else
{
Header += "," + dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
}
}
sbResult.AppendLine(Header);//添加表头
foreach(DataRow dr in dtExportTable.Rows)
{
string rowstring=string.Empty;
for(int i=0;i<ColCount;i++)
{
if(String.IsNullOrEmpty(rowstring))
{
rowstring=dr[i].ToString();
}
else
{
rowstring+=","+dr[i].ToString();
}
}
sbResult.AppendLine(rowstring); //添加行
}
File.WriteAllText(FilePath,sbResult.ToString());
}
/// 导出数据到CSV文件
/// </summary>
/// <param name="dtExportTable">需要导出的datatable</param>
/// <param name="dicColumnsInfo">导出的列字典,key datable中的列,value需要导出的列名称</param>
/// <param name="FilePath">导出的文件路径</param>
public static void ExportCSV(DataTable dtExportTable, Dictionary<string, string> dicColumnsInfo,string FilePath)
{
List<string> notExist=new List<string>();
if(dtExportTable!=null&&dicColumnsInfo!=null)
{
foreach(string key in dicColumnsInfo.Keys)
{
if(!dtExportTable.Columns.Contains(key))
{
notExist.Add(key);
}
}
}
foreach(string key in notExist)
{
dicColumnsInfo.Remove(key);
}
for(int i=dtExportTable.Columns.Count-1;i>=0;i--)
{
string colName=dtExportTable.Columns[i].ColumnName;
if(!dicColumnsInfo.ContainsKey(colName))
{
dtExportTable.Columns.RemoveAt(i);
}
}
if (dtExportTable == null || dtExportTable.Columns.Count <= 0 || dtExportTable.Rows.Count <= 0 || dicColumnsInfo == null || dicColumnsInfo.Count <= 0 || string.IsNullOrEmpty(FilePath))
throw new Exception("导出条件不满足!");
StringBuilder sbResult=new StringBuilder();
int ColCount=dtExportTable.Columns.Count;
string Header=string.Empty;
for(int i=0;i<ColCount;i++)
{
if(String.IsNullOrEmpty(Header))
{
Header = dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
}
else
{
Header += "," + dicColumnsInfo[dtExportTable.Columns[i].ColumnName];
}
}
sbResult.AppendLine(Header);//添加表头
foreach(DataRow dr in dtExportTable.Rows)
{
string rowstring=string.Empty;
for(int i=0;i<ColCount;i++)
{
if(String.IsNullOrEmpty(rowstring))
{
rowstring=dr[i].ToString();
}
else
{
rowstring+=","+dr[i].ToString();
}
}
sbResult.AppendLine(rowstring); //添加行
}
File.WriteAllText(FilePath,sbResult.ToString());
}
C# Datatable导出CSV算法
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。