下载

public void ExportExcel(DataTable dt)
{
if (dt.Rows.Count > 0)
{
//创建工作簿
NPOI.SS.UserModel.IWorkbook workbook = new NPOI.HSSF.UserModel.HSSFWorkbook();
//创建表
ISheet sheet = workbook.CreateSheet("vinkong");//表名
IRow row0 = sheet.CreateRow(0);
row0.CreateCell(0).SetCellValue("表名");
row0.CreateCell(1).SetCellValue("字段");
row0.CreateCell(2).SetCellValue("类型");
row0.CreateCell(3).SetCellValue("说明");
for (int r = 0; r < dt.Rows.Count; r++)
{
//创建行接受DataTable的行数据
IRow row = sheet.CreateRow(r + 1);
row.CreateCell(0).SetCellValue(dt.Rows[r]["TableName"].ToString());
row.CreateCell(1).SetCellValue(dt.Rows[r]["Field"].ToString());
row.CreateCell(2).SetCellValue(dt.Rows[r]["Type"].ToString());
row.CreateCell(3).SetCellValue(dt.Rows[r]["Description"].ToString());
}
string filePath = Server.MapPath("~/uploads/" + $"导出数据库表结构_{Guid.NewGuid()}.xls");

//写文件
FileStream file = new FileStream(filePath, FileMode.Create);
workbook.Write(file);
file.Close();


//下载
FileInfo fileInfo = new FileInfo(filePath);
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.AddHeader("Content-Disposition", "attachment;filename=" + fileInfo.Name);
Response.AddHeader("Content-Length", fileInfo.Length.ToString());
Response.AddHeader("Content-Transfer-Encoding", "binary");
Response.ContentType = "application/octet-stream";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");
Response.WriteFile(fileInfo.FullName);
Response.Flush();
//删除文件
System.IO.File.Delete(filePath);

Response.End();
}
else
{
Response.Write("<script>alert('导出失败!')</script>");
}
}

posted @   竹林听雨行  阅读(86)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示