代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Asp.Net
】
导出Excel
作者:
CSDN
/ 发布于
2012/1/11
/
656
<div>/// <summary> /// 导出Excel /// </summary> /// <param name="dtTemp"></param> /// <param name="ServerPath"></param> /// <param name="TextName"></param> /// <param name="fc">将number格式化成string</param> public static void ExportTasks(System.Data.DataTable dtTemp,string ServerPath,string TextName,int fc,string sName) { // 定义要使用的Excel 组件接口 // 定义Application 对象,此对象表示整个Excel 程序 Application excelApp = null; // 定义Workbook对象,此对象代表工作薄 Workbook workBook; // 定义Worksheet 对象,此对象表示Execel 中的一张工作表 Worksheet ws = null; //定义Range对象,此对象代表单元格区域 Range range; int dcell = 1; int rowindex = 0; int colindex = 0; int rowcount = dtTemp.Rows.Count; int colcount = dtTemp.Columns.Count; try { //初始化 Application 对象 excelApp excelApp = new Application(); //在工作薄的第一个工作表上创建任务列表 workBook = excelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet); ws = (Worksheet)workBook.Worksheets[1]; // 命名工作表的名称为 ws.Name = !string.IsNullOrEmpty(sName) ? sName : "Sheet1" ; //创建缓存 Object[,] objdata = new object[rowcount + 1, colcount]; //创建标题 foreach (System.Data.DataColumn dc in dtTemp.Columns) { objdata[rowindex, colindex++] = dc.ColumnName; } //获取数据 for (int i = 0; i < rowcount; i++) { dcell = 0; for (int j = 0; j < colcount; j++) { objdata[i + 1, dcell++] = dtTemp.Rows[i][dtTemp.Columns[j].ColumnName].ToString(); } } //写入Excel range = ws.get_Range(excelApp.Cells[1, 1], excelApp.Cells[rowcount + 1, colcount]); //range.NumberFormatLocal = "@";//所有字段格式化为文本格式 ws.get_Range(excelApp.Cells[2, fc], excelApp.Cells[rowcount + 1, fc]).NumberFormatLocal = "@"; range.Value2 = objdata; System.Windows.Forms.Application.DoEvents(); //设置格式 range = ws.get_Range(excelApp.Cells[1, 1], excelApp.Cells[1, colcount]); range.Font.Bold = true;//标题粗体 excelApp.Cells.HorizontalAlignment = Constants.xlCenter; //全局左对齐 excelApp.Cells.EntireColumn.AutoFit(); range = ws.get_Range(excelApp.Cells[1, 1], excelApp.Cells[rowcount + 1, colcount]); range.Borders.LineStyle = 1; //range.Font.Bold = true; //标题粗体 //显示 Excel //excelApp.Visible = true; workBook.SaveCopyAs(ServerPath.Replace("//", "\\") + TextName + ".xls"); workBook.Close(false, null, null); excelApp.Quit(); ws = null; } catch (Exception ex) { WriteLog.SetErrorMsg("ExportTasks", "", ex.Message); //处理错误 excelApp.Quit(); throw ex; } } /// <summary> /// 导出Excel /// </summary> /// <param name="dtTemp"></param> public static void ExportCMB(System.Data.DataTable dtTemp, string ServerPath, string TextName) { // 定义要使用的Excel 组件接口 // 定义Application 对象,此对象表示整个Excel 程序 Application excelApp = null; // 定义Workbook对象,此对象代表工作薄 Workbook workBook; // 定义Worksheet 对象,此对象表示Execel 中的一张工作表 Worksheet ws = null; //定义Range对象,此对象代表单元格区域 Range range; int dcell = 1; int colindex = 0; int rowcount = dtTemp.Rows.Count; int colcount = 14; try { //初始化 Application 对象 excelApp excelApp = new Application(); //在工作薄的第一个工作表上创建任务列表 workBook = excelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet); ws = (Worksheet)workBook.Worksheets[1]; // 命名工作表的名称为 ws.Name = "Sheet1"; //创建缓存 Object[,] objdata = new object[rowcount + 3, colcount]; objdata[0, 0] = "代发工资表"; objdata[1, 0] = "TF:QY1CWS1"; //创建标题 foreach (System.Data.DataColumn dc in dtTemp.Columns) { objdata[2, colindex++] = dc.ColumnName; } //获取数据 for (int i = 0; i < rowcount; i++) { dcell = 0; for (int j = 0; j < colcount; j++) { objdata[i + 3, dcell++] = dtTemp.Rows[i][dtTemp.Columns[j].ColumnName].ToString(); } } //写入Excel range = ws.get_Range(excelApp.Cells[1, 1], excelApp.Cells[rowcount + 3, colcount]); ws.get_Range(excelApp.Cells[4, 12], excelApp.Cells[rowcount + 3, 12]).NumberFormatLocal = "@"; //range.NumberFormatLocal = "@"; range.Value2 = objdata; range.Font.Size = 10; System.Windows.Forms.Application.DoEvents(); //设置格式 excelApp.Cells.HorizontalAlignment = Constants.xlLeft; //全局左对齐 excelApp.Cells.EntireColumn.AutoFit(); range = ws.get_Range(excelApp.Cells[3, 1], excelApp.Cells[rowcount + 3, colcount]); //range.BorderAround(XlLineStyle.xlContinuous, XlBorderWeight.xlThick, XlColorIndex.xlColorIndexAutomatic, System.Drawing.Color.Black.ToArgb()); range.Borders.LineStyle = 1; //显示 Excel //excelApp.Visible = true; workBook.SaveCopyAs(ServerPath.Replace("//", "\\") + TextName + ".xls"); workBook.Close(false, null, null); excelApp.Quit(); ws = null; } catch (Exception ex) { WriteLog.SetErrorMsg("ExportICBC", "", ex.Message); //处理错误 excelApp.Quit(); throw ex; } } }
试试其它关键字
导出Excel
同语言下
.
gzip压缩
.
实现http多线程断点续传下载文件
.
实现多线程断点续传下载大文件
.
生成字符串的 CheckSum
.
根据 UserAgent 获取浏览器的类型和版本
.
根据 Agent 判断是否是智能手机
.
隐藏手机号中间四位为*方法
.
合并图片(二维码和其他图片合并)
.
ASP.NET CORE中判断是否移动端打开网页
.
ASP.NET(C#)实现页面计时(定时)自动跳转
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
CSDN
贡献的其它代码
(
27
)
.
xml操作类
.
完全无组件,不用调用Excel.exe 导出数据到Excel
.
DropDownList手动构造一个下拉树形
.
判断是否低于IE6的版本
.
javascript 鼠标拖拉画图
.
取汉字首字母
.
字符串格式化通用类
.
mssql海量高效分页存储过程
.
.net 获取远程IP 得到省市
.
javascript 模仿windows拖动 封装类
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3