在delphi程序中取excel文件的行数。出现问题?(20分)

  • 主题发起人 主题发起人 chessll
  • 开始时间 开始时间
C

chessll

Unregistered / Unconfirmed
GUEST, unregistred user!
利用UsedRange.Rows.count取行数为20行,
而excel文件明明为120行,在文件没有行合并,
show出excel单元格的内容如 cell (1,1),在excel中找不到?
 
发现列有合并,就会有问题?咋整?是不是vba的问题?
 
因为人家给出的excel文件没有规则,我必须一个个单元取值赋值给sql server表.,但程序中取得的指定位置的数据与execl文件相应位置的数据对不上.
 
用VBA得到EXCEL表格中的行数和列数
  每种方法中上面的是行数,下面的是列数。
方法1:
  ActiveSheet.UsedRange.Rows.Count
  ActiveSheet.UsedRange.Columns.Count
缺点:有时可能会比实际数大一些,原因是如果你把最后几行(列)数据清除后(非整行或整列删除),用这个命令仍返回未清除前的值。就是说现在虽然是空的,但是你曾经用过也算你的。

方法2:
  ActiveSheet.Range("A65535").End(xlUp).Row
  ActiveSheet.Range("IV1").End(xlToLeft).Column
  可以简写为:
  ActiveSheet.[A65536].End(xlUp).Row
  ActiveSheet.[IV1].End(xlToLeft).Column
缺点:只能计算出一列(行)的最后一个单元格所在的行(列)数。本例是只返回A列最后一个单元格所占的行数。

方法3:
  ActiveSheet.Cells.SpecialCells(xlCellTypeLastCell).Row
  ActiveSheet.Cells.SpecialCells(xlCellTypeLastCell).Column
  缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。

方法4:
  ActiveSheet.UsedRange.SpecialCells(xlCellTypeLastCell).Row
  ActiveSheet.UsedRange.SpecialCells(xlCellTypeLastCell).Column
  缺点:在工作表进行对删除或清除操作时也会变得比实际情况大。

方法5:
  Application.CountA(ActiveSheet.Range("A:A"))
  Application.CountA(ActiveSheet.Range("1:1"))
  只能统计一列(行)的实际使用情况,得到的不一定是最后一行(列)的位置。方法2的数值比此方法大时,说明在A列的数据间有空白未填写的单元格。

方法6:
  ActiveSheet.Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
  ActiveSheet.Cells.Find(What:="*", After:=[A1], SearchOrder:=xlByColumns, SearchDirection:=xlPrevious).Column
  效果同方法2

以上方法中比较常用的是方法1和方法2。
 
后退
顶部