前言

网上使用NPOI读取Excel文件的例子现在也不少,本文就是参考网上大神们的例子进行修改以适应自己需求的。

参考博文

http://www.cnblogs.com/restran/p/3889479.html

本文使用的NPOI版本是 2.1.1.0(.net2.0)  下载链接   https://files.cnblogs.com/files/masonblog/NPOI2-1-1DotNet2-0.zip

本例Excel表格   https://files.cnblogs.com/files/masonblog/NPOIExcelTestRun.zip

运行结果

示例代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.IO;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using NPOI.HSSF.UserModel; namespace CourseMgr
{
public partial class EntireSchoolCourse : PageBase
{
BLL.Course _CourseBLL = null;
Model.Course _CourseModel = null;
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ExportToExcelByTemplate();
}
} #region 根据学校课程表模板导出Excel表格 public void ExportToExcelByTemplate()
{
string sYear1 = base.YearBegin;
string sYear2 = base.YearEnd;
string sSemester = base.Term;
string sYear = sYear1 + "-" + sYear2;
try
{
#region 获取课程表数据
_CourseModel = new Model.Course
{
OrgNo = CurrentOperator.OrgNo,
YearStr = sYear,
Semester = sSemester
};
_CourseBLL = new BLL.Course();
DataTable dtResult = _CourseBLL.GetEntireSchoolCourse(_CourseModel);
#endregion #region 打开Excel表格模板,并初始化到NPOI对象中
IWorkbook wk = null;
string filePath = Server.MapPath(@"~/Upload/CourseExportTemplate/学校课程表模板.xls");
if (!File.Exists(filePath))
{
Windows.MessageBox(Page, "导出失败:课程表模板不存在!", MessageType.Normal);
return;
}
string extension = System.IO.Path.GetExtension(filePath);
FileStream fs = File.OpenRead(filePath);
if (extension.Equals(".xls"))
{
//把xls文件中的数据写入wk中
wk = new HSSFWorkbook(fs);
}
else
{
//把xlsx文件中的数据写入wk中
wk = new XSSFWorkbook(fs);
}
fs.Close();
#endregion #region 数据处理
//1.读取Excel表格中的第一张Sheet表
ISheet sheet = wk.GetSheetAt(0);
IRow row = null;//数据行
ICell cell = null;//数据行中的某列
//2.添加Excel数据行。处理表格的边框,没有数据的数据行就没有内外边框。
//获取数据行数(班级数量)
int iCount = dtResult.Rows.Count;
for (int i = 0; i < iCount - 1; i++)//循环次数:数据行-1,因为已经默认添加了一行Excel单元行。
{
//从第二行复制出新行,主要是单元格的属性已经在第二行中设置好。
sheet.CopyRow(2, 2 + 1 + i);
}
//3.填充数据
string sCourceTeacher = string.Empty;//从DataTable中获取的课程信息
string[] strCourceTeacher = null;//将课程名称和教师名称分割开
//3.1从索引2(第三行)开始填充单元格中的数据
for (int i = 2; i < iCount + 2; i++)
{
//3.2读取当前行的对象
row = sheet.GetRow(i);
if (row != null)
{
//3.3获取该行第一列,赋值班级名称
cell = row.GetCell(0);
cell.SetCellValue(dtResult.Rows[i - 2]["GradeName"].ToString() + dtResult.Rows[i - 2]["ClassName"].ToString());
//3.4循环获取后面列的对象
for (int j = 1; j < row.LastCellNum; j++)
{
cell = row.GetCell(j);
sCourceTeacher = dtResult.Rows[i - 2]["science" + GetWeekDaySectionByInt(j)].ToString();
//3.4.1如果未获取到该班级星期节次的信息,则赋值\
if (string.IsNullOrEmpty(sCourceTeacher))
{
cell.SetCellValue("\\");
}
//3.4.2获取到课程则进行赋值(课程名称在上,换行,教师名称在下)
else
{
strCourceTeacher = sCourceTeacher.Split('|');
cell.SetCellValue(strCourceTeacher[0] + "\n" + strCourceTeacher[1]);
}
}
}
}
#endregion #region 表格导出
System.IO.MemoryStream ms = new System.IO.MemoryStream();
wk.Write(ms);
Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", HttpUtility.UrlEncode("学校总课程表", System.Text.Encoding.UTF8)));
Response.BinaryWrite(ms.ToArray());
Response.End();
#endregion
}
catch (Exception ex)
{
LogWrite("导出课程表失败", ex.ToString(), CurrentOperator.Name, ResourceID);
Windows.MessageBox(Page, "导出课程表失败", MessageType.Normal);
}
} /// <summary>
/// 将列序号转换为节次和星期
/// </summary>
/// <param name="i"></param>
/// <returns></returns>
public string GetWeekDaySectionByInt(int i)
{
//i-1 ,因为第一列为标题列
int iWeekDay = (i - 1) / 8;
int iSection = (i - 1) % 8; return (iSection + 1).ToString() + (iWeekDay + 1).ToString();
}
#endregion
}
}

使用NPOI读取Excel表格内容并进行修改的更多相关文章

  1. C# 读取Excel表格内容,以及NPOI的使用

    在实际的开发中,我们可能需要读写word或者Excel的内容,在我开发的项目中,需要读取Excel的内容,并将相对应的内容存储到数据库中,这里简单跟大家分享一下,希望能够帮助一些人. 我相信在读写wo ...

  2. NPOI读取Excel表格类

    public class NPOIHelper    {        private HSSFWorkbook workbook;        public static IWorkbook Lo ...

  3. java 读取 excel 表格内容

    一.添加依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</ar ...

  4. 【第二篇】.NET用NPOI读取Excel表格并在页面预览

    博主用的是npoi2.0.1,支持.xls也支持.xlsx 直接上代码吧. <table class="table table-bordered table-striped" ...

  5. 使用POI读取excel文件内容

    1.前言 项目中要求读取excel文件内容,并将其转化为xml格式.常见读取excel文档一般使用POI和JExcelAPI这两个工具.这里我们介绍使用POI实现读取excel文档. 2.代码实例: ...

  6. asp.net 使用NPOI读取excel文件

    asp.net 使用NPOI读取excel文件内容 NPOI下载地址:NPOI public class ExcelHelper { /// <summary> /// 读取Excel文件 ...

  7. .NET Core 使用NPOI读取Excel返回泛型List集合

    我是一名 ASP.NET 程序员,专注于 B/S 项目开发.累计文章阅读量超过一千万,我的博客主页地址:https://www.itsvse.com/blog_xzz.html 网上有很多关于npoi ...

  8. php 读取excel表格中的内容

    <?php /** * excel表格内容在网页中显示 * * 首先需要下载PHPExcel 工具包 * 网址: http://phpexcel.codeplex.com/releases/vi ...

  9. NPOI读取Excel到集合对象

    之前做过的项目中有个需要读取Excel文件内容的需求,因此使用NPOI实现,写下以下代码,这个只是一个代码段,还有很多地方需要优化,希望能对大家有所帮助 public static IList< ...

随机推荐

  1. [python学习手册-笔记]003.数值类型

    003.数值类型 ❝ 本系列文章是我个人学习<python学习手册(第五版)>的学习笔记,其中大部分内容为该书的总结和个人理解,小部分内容为相关知识点的扩展. 非商业用途转载请注明作者和出 ...

  2. JQuery案例:折叠菜单

    折叠菜单(jquery) <html> <head> <meta charset="UTF-8"> <title>accordion ...

  3. Linux 系统故障排查,这里看过来

    来源:https://www.jianshu.com/p/0bbac570fa4c 导读 有时候会遇到一些疑难杂症,并且监控插件并不能一眼立马发现问题的根源.这时候就需要登录服务器进一步深入分析问题的 ...

  4. 心跳event

    在通过sessionID和passwd获取会话的时候会使原会话断开,后续的事件都变为disconnected,且zk会不断发送disconnected给原连接,connected给新连接

  5. 一次SQL注入导致的"越权"

    原文来自SecIN社区-作者:tkswifty 相关背景   在实际的业务开发中,SQL交互往往是业务系统中不可或缺的一项.在Java中提供了类似Mybatis.Hibernate.SpringDat ...

  6. C语言实现聊天室(windows版本)

    来源:微信公众号「编程学习基地」 目录 C语言聊天室 运行效果 分析设计 多线程 线程的同步 服务端设计 遇到的问题 C语言聊天室 基于 tcp 实现群聊功能,本项目设计是在windows环境下基于套 ...

  7. [从源码学设计]蚂蚁金服SOFARegistry之消息总线

    [从源码学设计]蚂蚁金服SOFARegistry之消息总线 目录 [从源码学设计]蚂蚁金服SOFARegistry之消息总线 0x00 摘要 0x01 相关概念 1.1 事件驱动模型 1.1.1 概念 ...

  8. bootstrap火速布局"企业级"页面

    套娃 .container(两边有margin)/container-fluid(无) 大盒,写一个当爹就行 .row 行 .col 列 列中可再嵌套行和列 大小 把屏幕分成十二列看 .col-(xs ...

  9. K 均值算法-如何让数据自动分组

    公号:码农充电站pro 主页:https://codeshellme.github.io 之前介绍到的一些机器学习算法都是监督学习算法.所谓监督学习,就是既有特征数据,又有目标数据. 而本篇文章要介绍 ...

  10. Spring Boot + RabbitMQ 使用示例

    基础知识 虚拟主机 (Virtual Host): 每个 virtual host 拥有自己的 exchanges, queues 等 (类似 MySQL 中的库) 交换器 (Exchange): 生 ...