protected void Page_Load(object sender, EventArgs e)
{
//直接在bin add referece search Microsoft.Office.Interop.Excel.dll (.net 4.5 version 好像是是 1.4.0.0.0)
string filePath = Request.MapPath(@"~\excel\someData.xlsx"); //excel文件路径(server path)
string sheetName = "Sheet1"; //文件中,哪一个sheet
string connectionString07 = String.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0;HDR=YES'", filePath);
//string connectionString03 = String.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=Excel 8.0", filePath);
string query = String.Format("select * from [{0}$]", sheetName);
OleDbConnection connection = new OleDbConnection(connectionString07);
OleDbDataAdapter adapter = new OleDbDataAdapter(query, connectionString07);
DataSet dataSet = new DataSet();
adapter.Fill(dataSet);
DataTable table = dataSet.Tables[];
}

注意 : 如果读取后要insert to SQL, 要注意格式和字的长度,把最长的放最上面,微软默认会依据前面8 rows来决定类型和长度等等。(如果遇到问题可以参考)

导出 excel 让游览器下载 (not ajax)

首先使用这个插件 http://epplus.codeplex.com/documentation (nuget可以下载)

更多功能介绍 : http://www.codeproject.com/Articles/680421/Create-Read-Edit-Advance-Excel-Report-in

refer : https://www.paragon-inc.com/resources/blogs-posts/easy_excel_interaction_pt1

然后 code :

using OfficeOpenXml;

public class Person
{
public string name { get; set; }
public int age { get; set; }
public bool isOK { get; set; }
public DateTimeOffset dt { get; set; }
public double dou { get; set; }
}
protected void Page_Load(object sender, EventArgs e)
{
try
{
List<Person> persons = new List<Person> {
new Person { name = "keatkeat", age = ,isOK = false,dt = DateTimeOffset.Now,dou = 50.66 },
new Person { name = "xinyao", age = ,isOK = true,dt = DateTimeOffset.Now,dou = 50.00 } }; using (ExcelPackage pck = new ExcelPackage())
{
//Create the worksheet
ExcelWorksheet ws = pck.Workbook.Worksheets.Add("Demo");
ws.Cells["A1"].LoadFromCollection<Person>(persons, true); //load data from collection
Response.Clear();
Response.AddHeader("content-disposition", "attachment; filename=file.xlsx"); //file name
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.BinaryWrite(pck.GetAsByteArray());
Response.End();
}
}
catch (Exception ex)
{
throw;
}
}

建议是开一个独立的 web form page 来处理,前端可以简单的用 window popup 来做下载 ^^

一些常用的 Excel 操作 :

merge & center

var cells = ws.Cells[, , , ]; //FromRow, FromColumn, ToRow, ToColumn , 是从1开始的不是0哦
cells = ws.Cells["A1,A2"]; //"A1,A2" 我们叫 address
cells.Merge = true;
cells.Style.HorizontalAlignment = ExcelHorizontalAlignment.Center;

Read data from excel

System.IO.FileInfo file = new System.IO.FileInfo(Server.MapPath(@"~\test.xlsx"));
using (ExcelPackage excel = new ExcelPackage(file))
{
ExcelWorksheet worksheet = excel.Workbook.Worksheets.First(s => s.Name == "table1");
//table size
//算法 : 假设你在 B2 写一个值,那么 row 是 2, column 是 2
var rowCount = worksheet.Dimension.End.Row;
var columnCount = worksheet.Dimension.End.Column; //first row is columns
var x = worksheet.Cells["A1,A2"]; //"A1,A2" 我们叫 address foreach (var firstRowCell in worksheet.Cells[, , , columnCount])
{
string value = firstRowCell.Text;
} //second row is data
for (var rowNumber = ; rowNumber <= worksheet.Dimension.End.Row; rowNumber++)
{
var row = worksheet.Cells[rowNumber, , rowNumber, worksheet.Dimension.End.Column];
foreach (var cell in row)
{
bool isDate = cell.Value is DateTime; //check 类型
string format = cell.Style.Numberformat.Format; //check format
string value = cell.Text;
}
}
}

读取和导出下载 excel 2003,2007 资料的更多相关文章

  1. Java Struts2读取Excel 2003/2007/2010例子

    Java读写Excel的包是Apache POI(项目地址:http://poi.apache.org/),因此需要先获取POI的jar包,本实验使用的是POI 3.9稳定版. Apache POI ...

  2. 在线读取Mongodb数据库下载EXCEL文件

    版本:Mongodb2.4.8 通过页面下载Excel文件 jsp <%@ page language="java" contentType="text/html; ...

  3. java导入导出下载Excel,xls文件(带下拉框)

    /** * 导入excel文件 * 2014-7-23 * @return */ @RequiresPermissions("plug:product:caiwu:upload") ...

  4. NOPI读取模板导出(Excel中追加数据)

    在Controller里,我们定义一个FileResult的Action,返回值是一个文件形式被浏览器下载下来. [HttpGet] public FileResult ExportProductLi ...

  5. 简单导出下载excel的方法

    简单导出excel方法 /// <summary> /// Excel打包下载 /// </summary> /// <returns></returns&g ...

  6. SQL Server带列名导出到Excel(Export to CSV with headers)的几个思路

    https://www.cnblogs.com/downmoon/archive/2012/05/04/2482995.html   SQL Server 2008中SQL应用系列及BI学习笔记系列- ...

  7. java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)

    使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...

  8. Excel导入导出,生成和下载Excel报表、附件等操作--ASP.NET

    public class OutExcel { public static void OutExcel_bb(DataTable dt, string thepath, string temppath ...

  9. java POI 解析excel 2003和2007 直接转为List<Map> 返回

    1.POI 官网下载jar包,3.5以上 2.项目导入jar包 3.参数:String数组--对应的excel列名对应的KEY,File  excel文件,sheetNumber ---excel的s ...

随机推荐

  1. Exception testing

    怎样去验证代码是否抛出我们期望的异常呢?虽然在代码正常结束时候验证很重要,但是在异常的情况下确保代码如我们希望的运行也很重要.比如说: new ArrayList<Object>().ge ...

  2. iOS开发之自定义输入框(利用UITextField及UITextView)

    drawRect的工作原理:首先苹果是不推荐我们直接使用drawRect进行工作的,直接调用他也是没有任何效果的.苹果要求我们调用UIView类中的setNeedsDisplay方法,则程序会自动调用 ...

  3. Selenium 初见

    Selenium名字的来源 在这里,我还想说一下关于Selenium名字的来源,很有意思的: >:Selenium的中文名为“硒”,是一种化学元素的名字,它对汞 (Mercury)有天然的解毒作 ...

  4. 在 iPad和 iPhone的浏览器上查看网页源代码

    今天使用iPad 处理OA上的问题,有个窗口不能正常工作,想查看一下源码,发现iPad中的 Safari和chrome 没有内置查看源码功能.查了几个资料,遇到的又是没抄全的,下面是safari的设置 ...

  5. [RxJS] Combining streams in RxJS

    Source: Link We will looking some opreators for combining stream in RxJS: merge combineLatest withLa ...

  6. C#导出数据到Excel通用的方法类

    导出数据到Excel通用的方法类,请应对需求自行修改. 资源下载列表 using System.Data; using System.IO; namespace IM.Common.Tools { p ...

  7. Creating a Swap Partition

    Creating a Swap Partition 1.   Use  fdisk /dev/vda  to open your disk in fdisk. (Use gdisk if you ar ...

  8. NYOJ-129 并查集

    这个题基本上是并查集稍微一变, 只是加了一些判断条件而已,就是将点合并成树, 最后遍历一下, 统计一下有多少棵树, 如果不是1的话, 肯定不是树,所以,可以根据这个来判断 #include <s ...

  9. SparseArray HashMap 稀疏数组 二分法

    简介 HashMap是java里比较常用的一个集合类,我们常用其来缓存一些处理后的结果,但是在Android项目中,Eclipse却给出了一个 performance 警告.意思就是说用SparseA ...

  10. 小学生之SpringMVC

    1. Springmvc是什么? Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职责解耦,基 ...