之前一直是使用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;