读取和导出下载 excel 2003,2007 资料
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 资料的更多相关文章
- Java Struts2读取Excel 2003/2007/2010例子
Java读写Excel的包是Apache POI(项目地址:http://poi.apache.org/),因此需要先获取POI的jar包,本实验使用的是POI 3.9稳定版. Apache POI ...
- 在线读取Mongodb数据库下载EXCEL文件
版本:Mongodb2.4.8 通过页面下载Excel文件 jsp <%@ page language="java" contentType="text/html; ...
- java导入导出下载Excel,xls文件(带下拉框)
/** * 导入excel文件 * 2014-7-23 * @return */ @RequiresPermissions("plug:product:caiwu:upload") ...
- NOPI读取模板导出(Excel中追加数据)
在Controller里,我们定义一个FileResult的Action,返回值是一个文件形式被浏览器下载下来. [HttpGet] public FileResult ExportProductLi ...
- 简单导出下载excel的方法
简单导出excel方法 /// <summary> /// Excel打包下载 /// </summary> /// <returns></returns&g ...
- SQL Server带列名导出到Excel(Export to CSV with headers)的几个思路
https://www.cnblogs.com/downmoon/archive/2012/05/04/2482995.html SQL Server 2008中SQL应用系列及BI学习笔记系列- ...
- java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)
使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...
- Excel导入导出,生成和下载Excel报表、附件等操作--ASP.NET
public class OutExcel { public static void OutExcel_bb(DataTable dt, string thepath, string temppath ...
- java POI 解析excel 2003和2007 直接转为List<Map> 返回
1.POI 官网下载jar包,3.5以上 2.项目导入jar包 3.参数:String数组--对应的excel列名对应的KEY,File excel文件,sheetNumber ---excel的s ...
随机推荐
- 《Linear Algebra and Its Applications》-chaper2-矩阵的逆
矩阵的逆: 逆矩阵的定义: 类比于我们在研究实数的时候回去讨论一个数的倒数,对应的,在矩阵运算中,当AB = I的时候,A,B互称为逆矩阵,这里的I类似实数中的1,表示单位矩阵,即对角线是1其余位置是 ...
- O - Steady Cow Assignment - POJ 3189(多重匹配+枚举)
题意:有N头奶牛,M个牛棚,每个牛棚都有一个容量,并且每个牛对牛棚都有一个好感度,现在重新分配牛棚,并且使好感觉最大的和最小的差值最小. 分析:好感度貌似不多,看起来可以枚举一下的样子,先试一下把 注 ...
- 深入理解object C中复制对象的用法(一)
第一.复制对象的基本概念 复制一个对象为副本,开辟一块新的内存来存储副本对象. 第二.如果一个对象想具备复制的功能,必须实现<NSCopying>协议和<NSMutableCopyi ...
- DBParameter比拼接字符串慢的解决办法
List<DBParameter> param = new List<DBParameter>(){ new DBParameter("@Question ...
- 标准的数据获取 -ios
#define kBgQueue dispatch_get_global_queue( DISPATCH_QUEUE_PRIORITY_DEFAULT, 0) #define kLatestKivaL ...
- 032数值的整数次方(keep it up)
剑指offer中题目:http://ac.jobdu.com/problem.php? pid=1514 题目描写叙述: 给定一个double类型的浮点数base和int类型的整数exponent. ...
- Disposable microfluidic devices: fabrication, function, and application Gina S. Fiorini and Daniel T
Disposable microfluidic devices: fabrication, function, and application Gina S. Fiorini and Daniel T ...
- shell 中条件判断
if 中的 -z 到 -d 的意思 2011-09-05 10:30 [ -a FILE ] 如果 FILE 存在则为真. [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真. [ ...
- Qt 内存泄漏测试
在说Qt的内存测试之前,首先需要说明和肯定的一点是:Qt是绝对没有内存泄漏的,我们必须相信这一点. 接下来,说明一下基于Linux的Qt内存测试工具及其用法和说明: 一.内存测试工具Valgrind ...
- Laravel No such file or directory in /bootstrap/autoload.php on line 17
具体错误如下: Warning: require(../vendor/autoload.php) [function.require]: failed to open stream: No such ...