欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# 得到EXCEL表格中的有效行数和列数

程序员文章站 2022-07-04 23:28:34
每种方法中上面的是Excel的行数,下面的是Excel的列数。方法七:经过加工修改已经可以读出来的是有效数据行 using Excel = Microsoft.Office.Interop.Excel;//Excel表读写 Excel.Application app = new Excel.Appl ......

每种方法中上面的是excel的行数,下面的是excel的列数。方法七:经过加工修改已经可以读出来的是有效数据行

using excel = microsoft.office.interop.excel;//excel表读写
excel.application app = new excel.application();
object omissing = system.reflection.missing.value;
excel.workbook workbook = app.workbooks.open(excleitem.fullname, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing, omissing);
excel.sheets sheets = workbook.worksheets;//读取excel表格的标签页
excel.worksheet worksheet = (excel.worksheet)sheets.get_item(1);//读取第一张表

方法1:
  worksheet.usedrange.rows.count
  worksheet.usedrange.columns.count
  缺点:有时可能会比实际数大一些,原因是如果你把最后几行(列)数据清除后(非整行或整列删除),用这个命令仍返回未清除前的值。就是说现在虽然是空的,但是你曾经用过也算你的。

方法2:
  worksheet.range(“a65535″).end(xlup).row
  worksheet.range(“iv1″).end(xltoleft).column
  可以简写为:
  worksheet.[a65536].end(xlup).row
  worksheet.[iv1].end(xltoleft).column
  缺点:只能计算出一列(行)的最后一个单元格所在的行(列)数。本例是只返回a列最后一个单元格所占的行数。

方法3:
  worksheet.cells.specialcells(xlcelltypelastcell).row
  worksheet.cells.specialcells(xlcelltypelastcell).column
  缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。

方法4:
  worksheet.usedrange.specialcells(xlcelltypelastcell).row
  worksheet.usedrange.specialcells(xlcelltypelastcell).column
  缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。

方法5:
  worksheet.counta(activesheet.range(“a:a”))
  worksheet .counta(activesheet.range(“1:1″))
  只能统计一列(行)的实际使用情况,得到的不一定是最后一行(列)的位置。方法2的数值比此方法大时,说明在a列的数据间有空白未填写的单元格。

方法6:
  worksheet.cells.find(what:=”*”, after:=[a1], searchorder:=xlbyrows, searchdirection:=xlprevious).row
  worksheet.cells.find(what:=”*”, after:=[a1], searchorder:=xlbycolumns, searchdirection:=xlprevious).column
   效果同方法2

方法7:
  worksheet.usedrange.currentregion.rows.count
  worksheet.usedrange.currentregion.columns.count
  缺点:currentregion 所在位置的活动区域,若有空行或者空列,则空行或空列后面的无法获取到