ASP.NET中应用Excel:(3)访问工作表数据
2014-09-13 22:40
417 查看
已经创建了Excel.Application对象,并打开了工作薄,现在可以遍历工作表和单元格来获取数据了。并不是所有的单元格都有数据,大部分都是空的,因此XmlDocument来保存取得的数据是个不错的主意,还可以将XmlDocuemnt作为ScriptMethod的结果返回到客户端浏览器,使用JavaScript来生成表格,表现结果。根据我的经验,即使在服务端创建表格,也只消耗Excel操作的数百分之一的时间(实际数据:Excel操作耗时22.3秒,生成表格0.06秒,差距巨大)。
可以通过以下方式遍历工作表:
[csharp] view
plaincopy
sheets = workbook.Sheets;
for (int i = 1; i <= sheets.Count; i++) // 注意Excel的对象数组访问是以1为起始滴!
{
Excel.Worksheet sheet = (Excel.Worksheet)sheets.get_Item(i);// 获取工作表对象
......
releaseComObject(sheet); // 释放COM对象
sheet = null;
}
Excel的表格范围从A-IV列共256列,65536行,而且很多单元格是空的,完全遍历会消耗很多时间,因此,我们应该限定一个范围:
[csharp] view
plaincopy
Excel.Range range = sheet.get_Range("A1", "Z128"); // 范围为A1到Z128,注意Excel.Range对象会产生引用计数
Excel.Range rowRange = range.Rows; // 行对象,带"s",会产生引用计数
Excel.Range colRange = range.Columns; // 列对象,也会产生引用计数
object[,] data = (object[,])range.get_Value(Type.Missing); // 一次性获取范围内的所有数据,注意,获取的是值!
for (int r = rowRange.Count; r >= 1; r--) // 使用倒序遍历行
{
for ( int c = 1; c <= colRange.Count; c++ ) // 顺序访问列
{
if ( data[r, c] != null ) // 如果[r,c]位置的单元格没有数据,则值为null,这可以检测空单元格
{
Excel.Range cell = (Excel.Range)range.get_Item(r, c);
......
releaseComObject(cell); // 释放引用
cell = null;
}
}
}
在Excel 2003中,通过cell.Value属性访问值域,在Excel 2007中,则为cell.Value2。
对于以倒序的方式遍历行的方式的解释: 假设我们的XML格式如下: <WORKSHEET NAME="SheetXXX"> <ROW> <CELL>XXXXXXX</CELL> </ROW> </WORKSHEET> 由于Excel工作表数据集中在头部,后面基本是空的,填充XML时先生成CELL元素,插入到ROW元素中,再将ROW插入到WORKSHEET元素中。当以倒序遍历行时,如果行为空,不包括单元格数据,则ROW的ChildNodes.Count为0,如果这时WORKSHEET的ChildNodes为空,表示不包含行数据,则不需要将ROW插入到WORKSHEET中。这种情况直到遇到第一个包含数据单元格的行后改变。这时,行会添加到WORKSHEET的ChildNodes中。通过这种方式,可以跳过尾部没有数据的行,又不会略过夹在有数据的行中间的空行。
插入行元素的示例代码如下:
[csharp] view
plaincopy
if (row_elem.ChildNodes.Count > 0 || sheet_elem.ChildNodes.Count > 0) // 有行数据或空行则插入
{
sheet_elem.InsertBefore(row_elem, sheet_elem.FirstChild);
}
可以通过以下方式遍历工作表:
[csharp] view
plaincopy
sheets = workbook.Sheets;
for (int i = 1; i <= sheets.Count; i++) // 注意Excel的对象数组访问是以1为起始滴!
{
Excel.Worksheet sheet = (Excel.Worksheet)sheets.get_Item(i);// 获取工作表对象
......
releaseComObject(sheet); // 释放COM对象
sheet = null;
}
Excel的表格范围从A-IV列共256列,65536行,而且很多单元格是空的,完全遍历会消耗很多时间,因此,我们应该限定一个范围:
[csharp] view
plaincopy
Excel.Range range = sheet.get_Range("A1", "Z128"); // 范围为A1到Z128,注意Excel.Range对象会产生引用计数
Excel.Range rowRange = range.Rows; // 行对象,带"s",会产生引用计数
Excel.Range colRange = range.Columns; // 列对象,也会产生引用计数
object[,] data = (object[,])range.get_Value(Type.Missing); // 一次性获取范围内的所有数据,注意,获取的是值!
for (int r = rowRange.Count; r >= 1; r--) // 使用倒序遍历行
{
for ( int c = 1; c <= colRange.Count; c++ ) // 顺序访问列
{
if ( data[r, c] != null ) // 如果[r,c]位置的单元格没有数据,则值为null,这可以检测空单元格
{
Excel.Range cell = (Excel.Range)range.get_Item(r, c);
......
releaseComObject(cell); // 释放引用
cell = null;
}
}
}
在Excel 2003中,通过cell.Value属性访问值域,在Excel 2007中,则为cell.Value2。
对于以倒序的方式遍历行的方式的解释: 假设我们的XML格式如下: <WORKSHEET NAME="SheetXXX"> <ROW> <CELL>XXXXXXX</CELL> </ROW> </WORKSHEET> 由于Excel工作表数据集中在头部,后面基本是空的,填充XML时先生成CELL元素,插入到ROW元素中,再将ROW插入到WORKSHEET元素中。当以倒序遍历行时,如果行为空,不包括单元格数据,则ROW的ChildNodes.Count为0,如果这时WORKSHEET的ChildNodes为空,表示不包含行数据,则不需要将ROW插入到WORKSHEET中。这种情况直到遇到第一个包含数据单元格的行后改变。这时,行会添加到WORKSHEET的ChildNodes中。通过这种方式,可以跳过尾部没有数据的行,又不会略过夹在有数据的行中间的空行。
插入行元素的示例代码如下:
[csharp] view
plaincopy
if (row_elem.ChildNodes.Count > 0 || sheet_elem.ChildNodes.Count > 0) // 有行数据或空行则插入
{
sheet_elem.InsertBefore(row_elem, sheet_elem.FirstChild);
}
相关文章推荐
- ASP.NET中应用Excel:(3)访问工作表数据
- ASP.NET中应用Excel:12)其它读取Excel数据的方法(完)
- 在 ASP.NET 中访问 Excel 电子数据表
- ASP.NET中应用Excel:(1)访问Excel
- 利用ASP.NET来访问Excel文档+DATAGRID显示数据[注意:Excel中有图片]
- ASP.NET中应用Excel:(1)访问Excel
- ASP.NET中应用Excel:12)其它读取Excel数据的方法(完)
- 利用ASP.NET来访问Excel文档+DATAGRID显示数据[注意:Excel中有图片]
- ASP.NET中数据库数据导入Excel并打印(转载)
- 设计、实现一个 Asp.Net 应用的通用数据存取层
- 在ASP.NET访问Excel文件
- ASP.NET中数据库数据导入Excel并打印
- 使用ASP.NET(C#)查询和显示 Excel 数据
- ASP.NET在Windows2003下创建excel对象时,系统提示拒绝访问objApp = new Excel.Application() 出错
- 15秒:为ASP.NET应用缓存Oracle数据
- ASP.NET中将数据输出到Excel
- Script Callback in ASP.NET 2.0 (脚本回调,无刷新访问数据)
- [ASP.NET-C#]将DataSet、DataTable中的数据导出为Excel的解决方法
- 如何使用 ASP.NET、ADO.NET 和 Visual C# .NET 查询和显示 Excel 数据
- ASP.NET应用中缓存Oracle数据