//Datatable导出Excel private static void GridToExcelByNPOI(DataTable dt, string strExcelFileName)         {             try             { HSSFWorkbook workbook = new HSSFWorkbook();                  ISheet sheet = workbook.CreateSheet("Sheet1");                  ICellStyle HeadercellStyle = workbook.CreateCellStyle();                 HeadercellStyle.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thin;                 HeadercellStyle.BorderLeft = NPOI.SS.UserModel.BorderStyle.Thin;                 HeadercellStyle.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin;                 HeadercellStyle.BorderTop = NPOI.SS.UserModel.BorderStyle.Thin;                 HeadercellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;                 //字体                 NPOI.SS.UserModel.IFont headerfont = workbook.CreateFont();                 headerfont.Boldweight = (short)FontBoldWeight.Bold;                 HeadercellStyle.SetFont(headerfont);                   //用column name 作为列名                 int icolIndex = 0;                 IRow headerRow = sheet.CreateRow(0);                 foreach (DataColumn item in dt.Columns)                 {                     ICell cell = headerRow.CreateCell(icolIndex);                     cell.SetCellValue(item.ColumnName);                     cell.CellStyle = HeadercellStyle;                     icolIndex++;                 }                  ICellStyle cellStyle = workbook.CreateCellStyle();                  //为避免日期格式被Excel自动替换,所以设定 format 为 『@』 表示一率当成text來看                 cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("@");                 cellStyle.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thin;                 cellStyle.BorderLeft = NPOI.SS.UserModel.BorderStyle.Thin;                 cellStyle.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin;                 cellStyle.BorderTop = NPOI.SS.UserModel.BorderStyle.Thin;                   NPOI.SS.UserModel.IFont cellfont = workbook.CreateFont();                 cellfont.Boldweight = (short)FontBoldWeight.Normal;                 cellStyle.SetFont(cellfont);                  //建立内容行                 int iRowIndex = 1;                 int iCellIndex = 0;                 foreach (DataRow Rowitem in dt.Rows)                 {                     IRow DataRow = sheet.CreateRow(iRowIndex);                     foreach (DataColumn Colitem in dt.Columns)                     {                          ICell cell = DataRow.CreateCell(iCellIndex);                         cell.SetCellValue(Rowitem[Colitem].ToString());                         cell.CellStyle = cellStyle;                         iCellIndex++;                     }                     iCellIndex = 0;                     iRowIndex++;                 }                  //自适应列宽度                 for (int i = 0; i < icolIndex; i++)                 {                     sheet.AutoSizeColumn(i);                 }                  //写Excel                 FileStream file = new FileStream(strExcelFileName, FileMode.OpenOrCreate);                 workbook.Write(file);                 file.Flush();                 file.Close();                  MessageBox.Show(m_Common_ResourceManager.GetString("Export_to_excel_successfully"), m_Common_ResourceManager.GetString("Information"), MessageBoxButtons.OK, MessageBoxIcon.Information);             }             catch (Exception ex)             {                 ILog log = LogManager.GetLogger("Exception Log");                 log.Error(ex.Message + Environment.NewLine + ex.StackTrace);                 //记录AuditTrail                 CCFS.Framework.BLL.AuditTrailBLL.LogAuditTrail(ex);                  MessageBox.Show(m_Common_ResourceManager.GetString("Export_to_excel_failed"), m_Common_ResourceManager.GetString("Information"), MessageBoxButtons.OK, MessageBoxIcon.Information);             }             finally { workbook = null; }          }
/// <summary>         /// Excel文件导成Datatable         /// </summary>         /// <param name="strFilePath">Excel文件目录地址</param>         /// <param name="strTableName">Datatable表名</param>         /// <param name="iSheetIndex">Excel sheet index</param>         /// <returns></returns>         public static DataTable XlSToDataTable(string strFilePath, string strTableName,int iSheetIndex)         {              string strExtName = Path.GetExtension(strFilePath);              DataTable dt = new DataTable();             if (!string.IsNullOrEmpty(strTableName))             {                 dt.TableName = strTableName;             }              if (strExtName.Equals(".xls") || strExtName.Equals(".xlsx"))             {                 using (FileStream file = new FileStream(strFilePath, FileMode.Open, FileAccess.Read))                 {                     HSSFWorkbook workbook = new HSSFWorkbook(file);                     ISheet sheet = workbook.GetSheetAt(iSheetIndex);                      //列头                     foreach (ICell item in sheet.GetRow(sheet.FirstRowNum).Cells)                     {                         dt.Columns.Add(item.ToString(),typeof(string));                     }                      //写入内容                     System.Collections.IEnumerator rows = sheet.GetRowEnumerator();                     while(rows.MoveNext())                     {                         IRow row = (HSSFRow)rows.Current;                         if (row.RowNum == sheet.FirstRowNum)                         {                             continue;                         }                          DataRow dr = dt.NewRow();                         foreach (ICell item in row.Cells)                         {                             switch (item.CellType)                             {                                 case CellType.Boolean:                                     dr[item.ColumnIndex] = item.BooleanCellValue;                                     break;                                 case CellType.Error:                                     dr[item.ColumnIndex] = ErrorEval.GetText(item.ErrorCellValue);                                     break;                                 case CellType.Formula:                                     switch (item.CachedFormulaResultType)                                     {                                         case CellType.Boolean:                                             dr[item.ColumnIndex] = item.BooleanCellValue;                                             break;                                         case CellType.Error:                                             dr[item.ColumnIndex] = ErrorEval.GetText(item.ErrorCellValue);                                             break;                                         case CellType.Numeric:                                             if (DateUtil.IsCellDateFormatted(item))                                             {                                                 dr[item.ColumnIndex] = item.DateCellValue.ToString("yyyy-MM-dd hh:MM:ss");                                             }                                             else                                             {                                                 dr[item.ColumnIndex] = item.NumericCellValue;                                             }                                             break;                                         case CellType.String:                                             string str = item.StringCellValue;                                             if (!string.IsNullOrEmpty(str))                                             {                                                 dr[item.ColumnIndex] = str.ToString();                                             }                                             else                                             {                                                 dr[item.ColumnIndex] = null;                                             }                                             break;                                         case CellType.Unknown:                                         case CellType.Blank:                                         default:                                             dr[item.ColumnIndex] = string.Empty;                                             break;                                     }                                     break;                                 case CellType.Numeric:                                     if (DateUtil.IsCellDateFormatted(item))                                     {                                         dr[item.ColumnIndex] = item.DateCellValue.ToString("yyyy-MM-dd hh:MM:ss");                                     }                                     else                                     {                                         dr[item.ColumnIndex] = item.NumericCellValue;                                     }                                     break;                                 case CellType.String:                                     string strValue = item.StringCellValue;                                     if (string.IsNullOrEmpty(strValue))                                     {                                         dr[item.ColumnIndex] = strValue.ToString();                                     }                                     else                                     {                                         dr[item.ColumnIndex] = null;                                     }                                     break;                                 case CellType.Unknown:                                 case CellType.Blank:                                 default:                                     dr[item.ColumnIndex] = string.Empty;                                     break;                             }                         }                         dt.Rows.Add(dr);                     }                 }            }              return dt;         }

Datatable导出Excel的更多相关文章

  1. asp.net DataTable导出Excel 自定义列名

    1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...

  2. c# Datatable导出Excel

    using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; using System.Collections.Generic; ...

  3. C# DataTable导出EXCEL后身份证、银行卡号等长数字信息显示乱码解决

    在DataTable导出EXCEL后发现有些格式显示有问题,比如身份证.银行卡号等大于11位的数字显示为科学计数法.13681-1等 带中划线的两段数字显示为日期格式等. 处理方法如下: public ...

  4. 【转】C# DataTable 导出 Excel 进阶 多行表头、合并单元格、中文文件名乱码

    本文原创地址:http://blog.csdn.net/ranbolwb/article/details/8083983 ,转载请保留本行. 本例子是上一篇 DataTable 导出 Excel 的进 ...

  5. DataTable 更改在有数据列的类型方法+DataTable 导出excel功能

    /// <summary> /// 导出功能 /// </summary> /// <param name="sender"></para ...

  6. C# Datatable导出Excel方法

    C# 导出Excel方法  先引用下System.IO;System.data; 具体函数如下: public static bool ExportCSV(DataTable dt, string f ...

  7. NPOI DataTable导出excel

    /// <summary> /// DataTable导出到Excel文件 /// </summary> /// <param name="dtSource&q ...

  8. WinForm 使用 NPOI 2.2.1从datatable导出Excel

    最新的NOPI应该是2.3了,但在官网上还是2.2.1. 也是第一次使用NPOI来导出Excel文件. 在写的时候搜不到2.2.1的教程,搜了一个2.2.0的教程. 不过也没什么问题,NPOI是真的方 ...

  9. 【ASP.NET】DataTable导出EXCEL,弹窗提示下载保存(完整代码)

    //新建ASPX protected void Page_Load(object sender, EventArgs e) { DataTable dt = new DataTable(); Data ...

随机推荐

  1. HDU 1532 (Dinic算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1532 题目大意: 就是由于下大雨的时候约翰的农场就会被雨水给淹没,无奈下约翰不得不修建水沟,而且是网络 ...

  2. NeHe OpenGL教程 第四十二课:多重视口

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  3. EasyUI-draggable

    draggable用来在界面上创建一个可以拖动的元素,既然是可以拖动的元素,那么它在拖动过程中会有下面的几个事件:onBeforeDrag.onStartDrag.onDrag.onStopDrag. ...

  4. 转载__UI之Frgment

    http://www.cnblogs.com/plokmju/p/3239265.html 前言 开门见山开篇名义,本篇博客将讲解一下Android中Fragment的内容,必要的地方会提供相应的演示 ...

  5. Spring的AOP与代理

    spring 支持两种注入方式: setter/constructor 支持多种配置方式: xml/java5注解/java类配置 支持两种事务管理: 声明性/编程性 实际上上述方式只有一个就能保证系 ...

  6. 性能测试工具Gatling - 设置Recorder

    Gatling自带的Recorder,可以大大节省我们书写scenario的时间.     用法和selenium的IDE类似,作为一个代理服务器在browser和application之间做桥梁作用 ...

  7. minicom的安装及使用

    1.下载 sudo apt-get install minicom 2.运行 sudo minicom -s 3.修改端口 首先查看端口:ls /dev/tty...

  8. Java 线程间通讯(管道流方式)

    一.管道流是JAVA中线程通讯的常用方式之一,基本流程如下: 1)创建管道输出流PipedOutputStream pos和管道输入流PipedInputStream pis 2)将pos和pis匹配 ...

  9. IE10修改select样式

    一般我们针对webkit内核的,都使用-webkit-appearance来控制一些表单元素. 但是IE10如何来控制呢? select::-ms-expand{display:none;}

  10. django 模板if判断的时候==两边需要有空格

    比如 {%if a=='y'%}错误,{%if a =='y'%}也是错误的 只能是{%if a == 'y'%}这样才行