前言

网上使用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. JavaSE 学习笔记05丨泛型、集合

    Chapter. 10 泛型 10.1 泛型程序设计 泛型,指可以在类或方法中预支地使用未知的类型.泛型程序设计(Generic programming),意味着编写的代码可被很多不同类型的对象所重用 ...

  2. C语言讲义——头文件

    头文件.h Dev C++可以建C项目,也可以建C++项目,下面分C和C++两种情况讨论. c.h C语言中,头文件往往不是必须的,只是描述性的文件. 因此,C项目中可以没有.h文件. cpp.h 下 ...

  3. Java基础教程——System类

    System类 java.lang.System类代表当前Java程序的运行平台. |-可以做输入输出,垃圾回收:(此处不讲) |-可以获取时间: |-可以获取环境变量: |-可以获取系统信息: |- ...

  4. 教你C 语言简单编程速成

    我们将所有的 C 语言要素放置到一份易读的备忘录上. 1972 年,丹尼斯·里奇Dennis Ritchie任职于贝尔实验室Bell Labs,在几年前,他和他的团队成员发明了 Unix .在创建了一 ...

  5. Cisco交换机常见配置

    -------查看当前系统基础信息-------- sh version //查看当前IOS版本. sh running-config //查看当前系统中运行的配置信息 -------清除当前系统配置 ...

  6. [自学] MIT的EECS本科+研究生课程【持续更新中-2020.06.02】

    前言 我的本科是读的电子信息工程,研究生跟着老师做项目,参与到深度学习中来,毕业后做了算法工程师,工作之后愈发发现,不论从事什么岗位,基础都很重要,但现在也没有时间再读一遍本科了,自学的话也不知道从何 ...

  7. bypass disable_function

    windows 1.com组件绕过 <?php$command=$_POST['a'];$wsh = new COM('WScript.shell'); // 生成一个COM对象 Shell.A ...

  8. spring boot 访问外部http请求

    以前 访问外部请求都要经过 要用 httpClient  需要专门写一个方法  来发送http请求   这个这里就不说了 网上一搜全都是现成的方法 springboot 实现外部http请求 是通过F ...

  9. JZOJ 【NOIP2016提高A组集训第16场11.15】兔子

    JZOJ [NOIP2016提高A组集训第16场11.15]兔子 题目 Description 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3 ...

  10. 【GDKOI2014】JZOJ2020年8月13日提高组T4 内存分配

    [GDKOI2014]JZOJ2020年8月13日提高组T4 内存分配 题目 Description Input Output 输出m行,每行一个整数,代表输入中每次程序变化后系统所需要的空闲内存单位 ...