当我们打开一个Excel文件时,我们往往需要将它的数据进行处理,比如获取文件中所有行和列的数据,并进行显示。

这里,我简单的演示一下如何列举所有列名:

procedure TForm1.Button1Click(Sender: TObject);

Var

   book: IXLSWorkbook;

   i: integer;

begin

   book := TXLSWorkbook.Create();

   book.Open('c:\a.xls');

   // 列出excel中工作表1的所有已使用的列的列名

   for i := 1 to book.Sheets[1].UsedRange.LastCol do

      Memo1.Lines.Add(book.Sheets[1].UsedRange.Item[1, i].Value);

   book.Close;

end;

代码中,我们读取Sheet1第一行的所有列,并循环输出它的内容,请注意,这里应该使用UsedRange,而不是Cells,如果你使用Cells,那么LastCol将显示Excel支持的总列数,而不是实际已经使用的列数。

举一反三,那么如何获取所有行的数据呢?是不是只要使用UsedRange.LastRow就行了?那么,通过两个循环,就可以输出Excel中所有的内容了,是不是很简单?