【发布时间】:2013-03-25 06:13:28
【问题描述】:
我有一个以 csv 格式下载数据表值的代码。它工作正常,我可以下载 Csv。但问题是我的数据表在我下载 csv 时包含一些丹麦字符,csv 文件包含所有详细信息,但丹麦语字符被其他一些字符替换。这是我的代码。
string myXMLfile = Server.MapPath("~/App_Data/myfilecsv.xml");
DataSet ds = new DataSet();
System.IO.FileStream fsReadXml = new System.IO.FileStream(myXMLfile,
System.IO.FileMode.Open);
try
{
ds.ReadXml(fsReadXml);
DataTable dt = ds.Tables[1];
System.Text.StringBuilder sb = new StringBuilder();
IEnumerable<string> columnNames = dt.Columns.Cast<DataColumn>().
Select(column => column.ColumnName);
sb.AppendLine(string.Join(",", columnNames));
foreach (DataRow row in dt.Rows)
{
IEnumerable<string> fields = row.ItemArray.Select(field => field.ToString());
foreach (var item in fields)
{
sb.AppendFormat("\"{0}\",", item.Replace("\"", "\"\""));
}
sb = sb.Remove(sb.Length - 1, 1);
sb.Append("\n");
}
string attachment = "attachment; filename=mycsvfile.csv";
Response.ClearContent();
Response.AddHeader("content-disposition", attachment);
Response.ContentType = "application/csv";
Response.Write(sb.ToString());
Response.End();
}
catch (Exception ex)
{
umbraco.BusinessLogic.Log.Add(umbraco.BusinessLogic.LogTypes.Error, 00002, ex.ToString());
}
finally
{
fsReadXml.Close();
}
谁能给个解决办法???
【问题讨论】:
-
查看我对另一个问题的回答 (stackoverflow.com/questions/15577213/handling-null-in-linq/…);您应该在处理数据之前对其进行清理