GetExcelNpoi.cs

using System;
using System.Collections.Generic;// List
using System.Data;// DataTable
using System.Data.OleDb;// OleDbConnection,OleDbDataAdapter
using System.IO;// FileStream
using System.Text.RegularExpressions;// Regex
using System.Web;// HttpResponse
using System.Web.UI;// HtmlTextWriter
using System.Web.UI.WebControls;// GridView
using NPOI.HSSF.UserModel;// HSSFWorkbook,HSSFSheet,HSSFRow,HSSFCell
using NPOI.SS.UserModel;// IWorkbook,ISheet,IRow,ICell
using NPOI.SS.Util;// CellRangeAddress

/*/--------------------------------------------------------------------------------//
// GetExcelNpoi 的摘要说明
// 适用于 NPOI 2.0 版本
//--------------------------------------------------------------------------------/*/
public class GetExcelNpoi : System.Web.UI.Page
{
	// 构造函数
	public GetExcelNpoi() { }

	// GridView 导出 Excel
	// 注意: 使用此函数要定义事件 public override void VerifyRenderingInServerForm(Control control){}
	public void exportExcel(HttpResponse pageResponse,GridView drawGridView,string f_FileName)
	{
		pageResponse.Clear();
		pageResponse.Buffer = false;
		pageResponse.Charset = "GB2312";
		pageResponse.AppendHeader("Content-Disposition", "attachment;filename="+f_FileName+".xls");
		pageResponse.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
		pageResponse.ContentType = "application/ms-excel";
		pageResponse.Write("<meta http-equiv=Content-Type content=\"text/html; charset=GB2312\">");
		EnableViewState = false;
		System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
		HtmlTextWriter oHtmlTextWriter = new HtmlTextWriter(oStringWriter);
		drawGridView.RenderControl(oHtmlTextWriter);
		pageResponse.Write(oStringWriter.ToString());
		pageResponse.End();
	}

	// 索引字符转数字
	public static int toIndex(string columnName)
	{
		int index = 0;
		if (!Regex.IsMatch(columnName, @"^[A-Za-z]+$"))
		{
			return -1;
		}
		char[] chars = columnName.ToUpper().ToCharArray();
		for (int i = 0; i < chars.Length; i++)
		{
			index += ((int)chars[i] - (int)‘A‘ + 1) * (int)Math.Pow(26, chars.Length - i - 1);
		}
		return index - 1;
	}

	// 索引数字转字符
	public static string toColName(int index)
	{
		if (index < 0) return "";
		List<string> chars = new List<string>();
		do
		{
			if (chars.Count > 0) index--;
			chars.Insert(0, ((char)(index % 26 + (int)‘A‘)).ToString());
			index = (int)((index - index % 26) / 26);
		}
		while (index > 0);
		return String.Join(string.Empty, chars.ToArray());
	}

	// 从Excel导出到DataSet
	public DataSet getDataSet(string f_FilePath,string f_SheetName)
	{
		DataSet ds = new DataSet();
		string strConnect = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + f_FilePath + ";Extended Properties=‘Excel 8.0;HDR=Yes;IMEX=1‘;";
		try
		{
			OleDbConnection objConn = new OleDbConnection(strConnect);
			OleDbDataAdapter objDA = new OleDbDataAdapter("select * from [" + f_SheetName + "$]", strConnect);
			objConn.Open();
			objDA.Fill(ds, f_SheetName + "$");
			objConn.Close();
		}
		catch
		{

		}
		return ds;
	}

	// 从Excel导出到DataTable
	public System.Data.DataTable getDataTable(string f_FilePath,string f_SheetName)
	{
		System.Data.DataTable dt = new System.Data.DataTable();
		string strConnect = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + f_FilePath + ";Extended Properties=‘Excel 8.0;HDR=Yes;IMEX=1‘;";
		try
		{
			OleDbConnection objConn = new OleDbConnection(strConnect);
			OleDbDataAdapter objDA = new OleDbDataAdapter("select * from [" + f_SheetName + "$]", strConnect);
			objConn.Open();
			objDA.Fill(dt);
			objConn.Close();
		}
		catch
		{

		}
		return dt;
	}

	// 创建工作簿
	public HSSFWorkbook createWorkbook()
	{
		HSSFWorkbook wb = new HSSFWorkbook();
		return wb;
	}

	// 打开工作簿
	public HSSFWorkbook openWorkbook(string f_FilePath)
	{
		FileStream fs = File.Open(f_FilePath,FileMode.Open);
		HSSFWorkbook wb = new HSSFWorkbook(fs);
		fs.Close();
		return wb;
	}

	// 保存工作簿
	public void saveWorkbook(string f_FilePath,HSSFWorkbook f_Workbook)
	{
		FileStream fs = File.Open(f_FilePath,FileMode.OpenOrCreate);
		f_Workbook.Write(fs);
		fs.Close();
	}

	// 创建表
	public ISheet createSheet(HSSFWorkbook f_Workbook,string f_SheetName)
	{
		return f_Workbook.CreateSheet(f_SheetName);
	}

	// 打开表,重载
	public ISheet openSheet(HSSFWorkbook f_Workbook,string f_SheetName)
	{
		int index = f_Workbook.GetSheetIndex(f_SheetName);
		return index>=0 ? f_Workbook.GetSheetAt(index) : null;
	}

	// 打开表,重载
	public ISheet openSheet(HSSFWorkbook f_Workbook,int f_SheetIndex)
	{
		int index = f_SheetIndex;
		return index>=0 ? f_Workbook.GetSheetAt(index) : null;
	}

	// 获取指定索引表名
	public string getSheetName(HSSFWorkbook f_Workbook,int f_SheetIndex)
	{
		return f_Workbook.GetSheetName(f_SheetIndex);
	}

	// 获取指定表名索引
	public int getSheetIndex(HSSFWorkbook f_Workbook,string f_SheetName)
	{
		return f_Workbook.GetSheetIndex(f_SheetName);
	}

	// 统计表数
	public int countSheet(HSSFWorkbook f_Workbook)
	{
		return f_Workbook.NumberOfSheets;
	}

	// 统计行数
	public int countRow(ISheet f_Sheet)
	{
		int result = f_Sheet.LastRowNum;
		return result+1;
	}

	// 统计列数
	public int countColumn(ISheet f_Sheet)
	{
		int result = 0;
		int rowCount = f_Sheet.LastRowNum;
		for (int i=0;i<=rowCount;i++)
		{
			try
			{
				int colCount = f_Sheet.GetRow(i).LastCellNum;
				result = colCount>result ? colCount : result;
			}
			catch
			{

			}
		}
		return result;
	}

	// 读取单元格,行列从1开始
	public string getCell(ISheet f_Sheet,int f_RowIndex,int f_ColIndex)
	{
		if ((f_RowIndex < 1) || (f_ColIndex < 1)) return "";
		int rowIndex = f_RowIndex - 1;
		int colIndex = f_ColIndex - 1;
		ICell cell = f_Sheet.GetRow(rowIndex).GetCell(colIndex);
		return cell.ToString();
	}

	// 写入单元格,行列从1开始
	public bool setCell(ISheet f_Sheet,int f_RowIndex,int f_ColIndex,string f_Value)
	{
		bool result = true;
		if ((f_RowIndex < 1) || (f_ColIndex < 1)) return false;
		int rowIndex = f_RowIndex - 1;
		int colIndex = f_ColIndex - 1;
		int rowNum = f_Sheet.PhysicalNumberOfRows;
		if (f_RowIndex > rowNum)
		{
			for (int i = rowNum;i < (f_RowIndex - rowNum);i++)
			{
				f_Sheet.CreateRow(i);
			}
		}
		int colNum = f_Sheet.GetRow(rowIndex).PhysicalNumberOfCells;
		if (f_ColIndex > colNum)
		{
			for (int i = colNum;i < (f_ColIndex - colNum);i++)
			{
				f_Sheet.GetRow(rowIndex).CreateCell(i);
			}
		}
		try
		{
			ICell cell = f_Sheet.GetRow(rowIndex).GetCell(colIndex);
			cell.SetCellValue(f_Value);
		}
		catch
		{
			result = false;
		}
		return result;
	}

	// 设定合并单元格,行列从1开始
	public bool setMergeCell(ISheet f_Sheet,int f_sRow,int f_eRow,int f_sCol,int f_eCol)
	{
		bool result = false;
		if (0 <= f_Sheet.AddMergedRegion(new CellRangeAddress(f_sRow - 1,f_eRow - 1,f_sCol - 1,f_eCol - 1)))
		{
			result = true;
		}
		return result;
	}

	// 获取单元格信息,行列从1开始
	// 调用时要在输出变量前加 out
	public void getCellInfo(ISheet f_Sheet,int f_RowIndex,int f_ColIndex,out int f_RowSpan,out int f_ColSpan,out bool f_isMergeCell)
	{
		f_RowSpan = 0;
		f_ColSpan = 0;
		f_isMergeCell = false;
		if ((f_RowIndex < 1) || (f_ColIndex < 1)) return;
		int rowIndex = f_RowIndex - 1;
		int colIndex = f_ColIndex - 1;
		int regionsCuont = f_Sheet.NumMergedRegions;
		f_RowSpan = 1;
		f_ColSpan = 1;
		for (int i = 0; i < regionsCuont; i++)
		{
			CellRangeAddress range = f_Sheet.GetMergedRegion(i);
			f_Sheet.IsMergedRegion(range);
			if (range.FirstRow == rowIndex && range.FirstColumn == colIndex)
			{
				f_RowSpan = range.LastRow - range.FirstRow + 1;
				f_ColSpan = range.LastColumn - range.FirstColumn + 1;
				break;
			}
		}
		try
		{
			f_isMergeCell = f_Sheet.GetRow(rowIndex).GetCell(colIndex).IsMergedCell;
		}
		catch
		{
			f_isMergeCell = false;
		}
	}

}

GetExcelNpoi.cs,布布扣,bubuko.com

时间: 2024-10-12 16:28:16

GetExcelNpoi.cs的相关文章

CS文件类头注释

1.修改unity生成CS文件的模板(模板位置:Unity\Editor\Data\Resources\ScriptTemplates 文件名:81-C# Script-NewBehaviourScript.cs) 本人将模板修改为如下图(红框内的内容) 备注:在"#"之间的为可替换的参数 2.修改模板可替换参数,在工程项目Asset文件夹在创建Editor文件 在文件夹下添加AddFileHeadComment.cs文件 内容如下 参数内容根据个人需求修改

CS 和 BS 的区别和优缺点

bs是浏览器(browser)和服务器(server) cs是静态客户端程序(client)和服务器(server) 区别在于,虽然同样是通过一个程序连接到服务器进行网络通讯,但是bs结构的,客户端运行在浏览器里,比如你看百度,就是通过浏览器.还有一些bs结构的应用,比如中国电信,以及一些电子商务平台.用bs结构的好处是,不必专门开发一个客户端界面,可用asp,php,jsp等比较快速开发web应用的程序开发. cs结构的,要做一个客户端.网络游戏基本上大多是cs结构,比如你玩传奇,要专门开个传

微软SQLHelper.cs类 中文版

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Configuration; using System.Data; using System.Data.SqlClient; using System.Xml; using System.Collections; namespace LiuYanBanT { public class SqlHelper

AssemblyInfo.cs文件详解

一.前言 .net工程的Properties文件夹下自动生成一个名为AssemblyInfo.cs的文件,一般情况下我们很少直接改动该文件.但我们实际上通过另一个形式操作该文件.那就是通过在鼠标右键点击项目的属性进入“应用程序”->“程序集信息”,然后修改信息. 二.作用 通过特性(Attribute)来设置程序集(dll文件)的常规信息,供查看或作为配置信息供程序内部使用. 三.详解 // 程序集标题 [assembly:AssemblyTitle("程序集标题")] // 程

全局程序集GlobalAssemblyInfo.cs进行版本控制(引)

原文出自:http://blog.csdn.net/oyi319/article/details/5753311 1.全局程序集GlobalAssemblyInfo.cs 我们编写的一个解决方案,通常会包含多个项目,而每个项目都有单独的程序集信息AssemblyInfo.cs.但是,你会发现一个问题,这些AssemblyInfo.cs当中有一部分在重复的,若能把它们提取出来放入一个单一文件中,修改AssemblyInfo中的诸如产品名.产品版本.版本等信息会变得轻松.那么,这个程序集信息文件,我

【141030】CS结构的VC++远程控制程序源代码

CS结构的VC++远程控制程序源代码,类似于pcAnywhere的程序,程序分为主服务端和主控端.主控端也就是客户端,由用户发送指令到服务端后来控制受控计算机.因为服务端是安装在受控机上的,其程序原理与著名的远程控制软件PcAnywhere非常相似,只是只完成了基本功能,有兴趣的可自己扩展程序吧. 客户端: 服务端: 完整源码下载地址:点击下载

《CS:APP》 chapter 6 The Memory Hierarchy笔记

The Memory Hierarchy 6.1 Storage Technologies The earliest IBM PCs didn't even have a hard disk. 让我惊奇的是早期的IBM直接没有硬盘... 6.1.1 Random-Access Memory Random-access memory(RAM) comes in two varieties- static anddynamic . Static RAM (SRAM) is faster and si

CS游戏2--三次杀人机会,警察不能杀人

#coding=utf-8 import randomimport time ''' 本文章主要目主要有三个,1,随机增加5个系统人物,所有的都是随机产生的,2,人物角色如果是警察,则不能杀死警察,3,有三次机会杀死敌方 涉及的知识点有,随机数的产生,字典的存储和遍历 ''' list_kill=[0,1,1,1]list_name=range(10)dir_weapen={"AK47":2000,"匕首":500,"小手枪":1000}dir_

Atitit 软件架构方法的进化与演进cs bs soa roa &#160;msa&#160; attilax总结

Atitit 软件架构方法的进化与演进cs bs soa roa  msa  attilax总结 1.1. 软件体系架构是沿着单机到 CS 架构,再到 BS 的三层架构甚至多层架构逐步发展过来的,关于多层架构 1 1.2. 主进化路线Cs>> bs >>  SOA>>MSA(微服务架构1 1.3. 1 1.4. 面向资源体系架构(ROA)1 1.4.1. 管道和过滤器风格(数据流风格)2 1.5. 数据抽象与面向对象风格(调用/返回风格)2 1.6. 基于事件的隐式调用