代码语言
.
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轉DataTable的NPOI簡單範例
作者:
Dezai.CN
/ 发布于
2011/11/1
/
1344
using System.Data; using System.IO; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; public class NPOIHelper { public static DataTable ReadExcelAsTableNOPI(string fileName) { using (FileStream fs = new FileStream(fileName, FileMode.Open)) { HSSFWorkbook wb = new HSSFWorkbook(fs); Sheet sheet = wb.GetSheetAt(0); DataTable table = new DataTable(); //由第一列取標題做為欄位名稱 Row headerRow = sheet.GetRow(0); int cellCount = headerRow.LastCellNum; for (int i = headerRow.FirstCellNum; i < cellCount; i++) //以欄位文字為名新增欄位,此處全視為字串型別以求簡化 table.Columns.Add( new DataColumn(headerRow.GetCell(i).StringCellValue)); //略過第零列(標題列),一直處理至最後一列 for (int i = (sheet.FirstRowNum + 1); i < sheet.LastRowNum; i++) { Row row = sheet.GetRow(i); if (row == null) continue; DataRow dataRow = table.NewRow(); //依先前取得的欄位數逐一設定欄位內容 for (int j = row.FirstCellNum; j < cellCount; j++) if (row.GetCell(j) != null) //如要針對不同型別做個別處理,可善用.CellType判斷型別 //再用.StringCellValue, .DateCellValue, .NumericCellValue...取值 //此處只簡單轉成字串 dataRow[j] = row.GetCell(j).ToString(); table.Rows.Add(dataRow); } return table; } } } using System.Data; using System.IO; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; public class NPOIHelper { public static DataTable ReadExcelAsTableNOPI(string fileName) { using (FileStream fs = new FileStream(fileName, FileMode.Open)) { HSSFWorkbook wb = new HSSFWorkbook(fs); Sheet sheet = wb.GetSheetAt(0); DataTable table = new DataTable(); //由第一列取標題做為欄位名稱 Row headerRow = sheet.GetRow(0); int cellCount = headerRow.LastCellNum; for (int i = headerRow.FirstCellNum; i < cellCount; i++) //以欄位文字為名新增欄位,此處全視為字串型別以求簡化 table.Columns.Add( new DataColumn(headerRow.GetCell(i).StringCellValue)); //略過第零列(標題列),一直處理至最後一列 for (int i = (sheet.FirstRowNum + 1); i < sheet.LastRowNum; i++) { Row row = sheet.GetRow(i); if (row == null) continue; DataRow dataRow = table.NewRow(); //依先前取得的欄位數逐一設定欄位內容 for (int j = row.FirstCellNum; j < cellCount; j++) if (row.GetCell(j) != null) //如要針對不同型別做個別處理,可善用.CellType判斷型別 //再用.StringCellValue, .DateCellValue, .NumericCellValue...取值 //此處只簡單轉成字串 dataRow[j] = row.GetCell(j).ToString(); table.Rows.Add(dataRow); } return table; } } } 範例假設Excel第一列視為標題列,讀取各欄位值當成DataTable的Column名稱,建立欄位後,逐一讀取各列的資料新增為Row,其中欄位內容一律視為字串處置。 排版顯示純文字複製文字 <%@ Page Language="C#" %> <script type="text/C#" runat="server"> void Page_Load(object sender, EventArgs e) { System.Data.DataTable t = NPOIHelper.ReadExcelAsTableNOPI( Server.MapPath("~/App_Data/Koobe.xls")); GridView1.DataSource = t; GridView1.DataBind(); } </script> <!DOCTYPE html> <html xmlns="<a href="http://www.w3.org/1999/xhtml">http://www.w3.org/1999/xhtml</a>"> <body> <form id="form1" runat="server"> <asp:GridView ID="GridView1" runat="server"> </asp:GridView> </form> </body> </html> <%@ Page Language="C#" %> <script type="text/C#" runat="server"> void Page_Load(object sender, EventArgs e) { System.Data.DataTable t = NPOIHelper.ReadExcelAsTableNOPI( Server.MapPath("~/App_Data/Koobe.xls")); GridView1.DataSource = t; GridView1.DataBind(); } </script> <!DOCTYPE html> <html xmlns="<a href="http://www.w3.org/1999/xhtml">http://www.w3.org/1999/xhtml</a>"> <body> <form id="form1" runat="server"> <asp:GridView ID="GridView1" runat="server"> </asp:GridView> </form> </body> </html> 補充一點,因為Excel檔案中儲存的是資料的原值加格式、或是計算公式內容,並非套用格式及運算後的最終結果(這點在之前有說明過),故可能與Excel中看到的有點誤差。如下例中的第一列備註就由2011/5/12變成5/12/11,在應用時需留意。
试试其它关键字
NPOI簡單範例
同语言下
.
gzip压缩
.
实现http多线程断点续传下载文件
.
实现多线程断点续传下载大文件
.
生成字符串的 CheckSum
.
根据 UserAgent 获取浏览器的类型和版本
.
根据 Agent 判断是否是智能手机
.
隐藏手机号中间四位为*方法
.
合并图片(二维码和其他图片合并)
.
ASP.NET CORE中判断是否移动端打开网页
.
ASP.NET(C#)实现页面计时(定时)自动跳转
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Dezai.CN
贡献的其它代码
(
4037
)
.
多线程Socket服务器模块
.
生成随机密码
.
清除浮动样式
.
弹出窗口居中
.
抓取url的函数
.
使用base HTTP验证
.
div模拟iframe嵌入效果
.
通过header转向的方法
.
Session操作类
.
执行sqlite输入插入操作后获得自动编号的ID
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3