asp.net中gridview中数据保存为cvs格式,datatable中

跳出路径选择框后将datatable中数据保存到用户指定路径:
private void ExportTableToExcel(DataTable dt, string FileName)
 {
 string title = "";
 for (int i = 0; i < dt.Columns.Count; i++)
 {

 title += dt.Columns[i].ColumnName + ",";
 }
 title += "/n";
 string content = "";
 for (int i = 0; i < dt.Rows.Count; i++)
 {
 for (int j = 0; j < dt.Columns.Count; j++)
 {
 string s = dt.Rows[i][j].ToString();
 if (s.Trim() == " ")
 {
 s = "";
 }
 content += s + ",";
 }
 content += "/n";
 }
 string data = title + content;
 Response.ClearHeaders();
 string temp = string.Format("attachment;filename={0}", FileName);
 Response.Charset = "gb2312";
 Response.ContentEncoding = System.Text.Encoding.Default;
 Response.AppendHeader("Content-disposition", temp);
 Response.ContentType = "application/vnd.xls";
 Response.Write(data);
 Response.End();
 }

直接将表格保存:
public static bool ExportCSV(GridView gv, string FileName)
 {
 if (gv.Rows.Count == 0)
 {
 return true;
 }
 string path = @"c:/SmsFile";
 if (!System.IO.Directory.Exists(path))
 {
 System.IO.Directory.CreateDirectory(path);
 }
 FileName = path + "//" + FileName;
 try
 {
 FileStream fs = new FileStream(FileName, FileMode.Create);
 StreamWriter sw = new StreamWriter(fs, System.Text.Encoding.Unicode);

 string title = "";
 for (int i = 0; i < gv.Columns.Count; i++)
 {
 if (gv.Columns[i].Visible)
 {
 title = gv.Columns[i].HeaderText;
 sw.Write(title);
 sw.Write("/t");
 }
 }
 sw.WriteLine("");

 for (int i = 0; i < gv.Rows.Count; i++)
 {
 for (int j = 0; j < gv.Columns.Count; j++)
 {
 if (gv.Columns[j].Visible)
 {
 string s = gv.Rows[i].Cells[j].Text;
 if (s.Trim() == " ")
 {
 s = "";
 }
 sw.Write(s);
 sw.Write("/t");
 }
 }
 sw.WriteLine("");
 sw.Flush();
 }

 fs.Close();

 return true;
 }
 catch
 {
 return false;
 }
 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值