前言

网上使用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. Java基础教程——注释

    Java注释 三种注释: public class 注释 { // (1)单行注释 /* * (2)多行注释 */ /**+回车 * (3)文档注释:可以通过javadoc工具生成HTML文档 * & ...

  2. redis 一致性分析

    转载: https://blog.csdn.net/qq32933432/article/details/108690254

  3. for循环与while循环

    1.两中循环的语法结构 for循环结构: for(表达式1;表达式2;表达式3) { 执行语句; } while循环结构: while(表达式1) { 执行语句; } 2.两者区别: 应用场景:由于f ...

  4. ActiveMQ Cannot send, channel has already failed: tcp:127.0.0.1:8161

    仅针对如下错误内容: Cannot send, channel has already failed: tcp://127.0.0.1:8161 一种尝试解决,修改连接端口为 61616: tcp:/ ...

  5. 《技术男征服美女HR》—Fiber、Coroutine和多线程那些事

    1.起点 我叫小白,坐在这间属于华夏国超一流互联网公司企鹅巴巴的小会议室里,等着技术面试官的到来. 令我感到不舒服的,是坐在我对面的那位HR美女一个劲儿的盯着我打量!虽说本人帅气,但是也不能这么毫无顾 ...

  6. paddleocr安装笔记

    下载解压安装 wget http://npm.taobao.org/mirrors/python/3.7.6/Python-3.7.6.tgztar xvf Python-3.7.6.tgzcd Py ...

  7. k8s实验操作记录文档

    k8s实验操作记录文档,仅供学习参考! 文档以实验操作的过程及内容为主进行记录,涉及少量的介绍性文字(来自网络开源). 仅汇总主题所有链接,详细内容查看需要切换到相关链接.https://github ...

  8. Codeforces Round 665 (div2)

    2020.8.22 装修完了我的博客,喜欢这个造型,挂上友链就更好了 昨天cf就是一个彻头彻尾的悲剧,本来能上蓝,结果因为在A题耽误时间过多导致掉了30分,不过没关系,这算是一个小波动吧,影响不了什么 ...

  9. LoadRunner 多用户并发 登录,上传数据,登出的脚本教程

    这里记录 Web/Http  模式,模拟多用户并发进行  : 登录,上传数据,退出登录一整套流程.并发的用户量多少,可自定义.这里不介绍录屏的方式,是自己写脚本去执行的. 1.安装loadRunner ...

  10. CommandLineRunner 可能会导致你的应用宕机停止,我劝你耗子尾汁

    hello,大家好,我是小黑,又和大家见面啦~~ 如果你去某度搜索关键词 CommandLineRunner 初始化资源 ,截止小黑同学写这篇推文之前,大概能收到 1,030,000 个结果. 网上大 ...