之前一直是使用XLSReadWriteII4,今天更新到XLSReadWriteII5,测试了一下,发现一些操作变化比较大,现将XLSReadWriteII5的使用示例写一下,以下是代码和生成的excel表格的效果:

procedure TForm1.Button1Click(Sender: TObject);

var

   i, n: Integer;

   XLS: TXLSReadWriteII5; // 引用XLSReadWriteII5, Xc12DataStyleSheet5, ShellAPI

begin

   XLS := TXLSReadWriteII5.Create(nil);

   try

      XLS.Clear;

      XLS.FileName := ExtractFilePath(paramstr(0)) + 'temp.xls';

      for i := 0 to 9 do

         XLS.Sheets[0].AsString[i, 0] := '标题' + IntToStr(i + 1);

      for i := 0 to 9 do

         for n := 1 to 19 do

            XLS.Sheets[0].AsString[i, n] := IntToStr(i + 1) + ':' + IntToStr(n);

 

      for i := 0 to 9 do // XLS.Sheets[0].LastCol do // 从第一列到最后一列

      begin

         for n := 0 to 19 do // 从第一行到最后一行

         begin

            XLS.Sheets[0].Range.Items[i, n, i, n].BorderOutlineStyle := cbsThin;

            XLS.Sheets[0].Range.Items[i, n, i, n].BorderOutlineColor := 0; // 黑色#0

            if n = 0 then

            begin

               XLS.Sheets[0].Cell[i, n].CellColorRGB := 16744448; // 橘黄#FF8000

               XLS.Sheets[0].Cell[i, n].FontColor := 16777215; // 白色#FFFFFF

            end

            else

               XLS.Sheets[0].Cell[i, n].CellColorRGB := 16777165; // 杏仁灰#FFFFCD

         end;

         XLS.Sheets[0].AutoWidthCol(i); // 每列为自动宽度

      end;

      XLS.Write;

      ShellExecute(0, 'Open', PChar(ExtractFilePath(paramstr(0)) + 'temp.xls'), nil, nil, SW_SHOW);

   finally

      XLS.Free;

   end;

end;