Flexcel笔记

1.引入:

uses {$IFDEF LINUX}SKIA.FlexCel.Core{$ELSE}{$IFDEF FIREMONKEY}
FMX.FlexCel.Core{$ELSE}VCL.FlexCel.Core{$ENDIF}{$ENDIF}
 

2.核心单元介绍

FlexCel. XlsAdapter:这是FlexCel xls/x引擎。如果您正在处理xls或xlsx文件,则需要使用此单元。很少有情况下您不需要使用此单元,例如手动创建pdf文件。但通常您需要使用它。

FlexCel. Render:这是FlexCel渲染引擎,它将xls/x文件中的内容渲染为图像、pdf、html或其他类似的文件类型。每当您想将xls/x文件导出为不同的格式时,您都需要使用FlexCel.Render。在自动拟合行或列时,您还需要使用此单元,因为为了测量单元格中的字符串有多大,FlexCel需要将其渲染为内部图像。

•FlexCel.Pdf这是FlexCel Pdf引擎。请注意,这是一个通用的pdf引擎,不依赖于xls/x文件。要将xls/x文件转换为pdf,您仍然需要使用FlexCel.Render,它是可以将xls/x文件“转换”为图像的引擎。如果您直接使用pdf引擎,或者通常如果您正在处理pdf文件,则需要使用FlexCel. Pdf。即使不完全需要将Excel文件转换为pdf,它也具有导出时访问完整pdf功能可能需要的枚举和类。•FlexCel.Report这是FlexCel报告引擎。如果您使用TFlexCelReport类进行Excel报告,

3.创建一个Excel

1.引用单元

uses
...
System.IOUtils,
VCL.FlexCel.Core, FlexCel.XlsAdapter;
procedure CreateExcelFile;
var
xls: TXlsFile;
begin
//创建一个新的文件为Excel 2019.
//Different Excel versions can have different formatting when they create
//an empty file, so for example
//Excel 2003 will have a default font of Arial, and 2019 will use Calibri.
//This format is anyway the starting format, you can change it all later.
xls := TXlsFile.Create(1, TExcelFileFormat.v2019, true);
try
//Enters a string into A1
xls.SetCellValue(1, 1, 'Hello from FlexCel!');
//Enters a number into A2.
//Note that xls.SetCellValue(2, 1, '7') would enter a string.
xls.SetCellValue(2, 1, 7);
//Enter another floating point number.
//All numbers in Excel are floating point,
//so even if you enter an integer, it will be stored as double.
xls.SetCellValue(3, 1, 11.3);
//Enters a formula into A4.
xls.SetCellValue(4, 1, TFormula.Create('=Sum(A2:A3)'));
//Saves the file to the "Documents" folder.
xls.Save(TPath.Combine(TPath.GetDocumentsPath, 'test.xlsx'));
finally
xls.Free;
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
CreateExcelFile;
end;

2.读取文件

procedure ReadExcelFile(const aMemo: TMemo);
var
xls: TXlsFile;
row, colIndex: integer;
XF: integer;
cell: TCellValue;
addr: TCellAddress;
s: string;
begin
xls := TXlsFile.Create(TPath.Combine(TPath.GetDocumentsPath, 'test.xlsx'));
try
xls.ActiveSheetByName := 'Sheet1'; //we'll read sheet1. We could loop over
the existing sheets by using xls.SheetCount and xls.ActiveSheet
for row := 1 to xls.RowCount do
begin
for colIndex := 1 to xls.ColCountInRow(row) do //Don't use xls.ColCount
as it is slow: See http://www.tmssoftware.biz/flexcel/doc/vcl/guides/
performance-guide.html#avoid-calling-colcount
begin
XF := -1;
cell := xls.GetCellValueIndexed(row, colIndex, XF);
addr := TCellAddress.Create(row, xls.ColFromIndex(row, colIndex));
s := ('Cell ' + addr.CellRef + ' has ');
if (cell.IsString) then s := s + 'a string: ' + cell.ToString
else if (cell.IsNumber) then s := s + 'a number: ' + FloatToStr(cell.AsN
umber)
else if (cell.IsBoolean) then s := s + 'a boolean: ' + BoolToStr(cell.As
Boolean)
else if (cell.IsError) then s := s + 'an error: ' + cell.ToString
else if (cell.IsFormula) then s := s + 'a formula: ' + cell.AsFormula.Te
xt
else s := s + ('Error: Unknown cell type');
aMemo.Lines.Add(s);
end;
end;
finally
xls.Free;
end;
end;
procedure TForm1.Button2Click(Sender: TObject);
begin
ReadExcelFile(Memo1);
end;
FlexCel Studio for VCL and FireMonkey 7.1.0 Page 5 of 10

4.Exporting a file to pdf

uses ..., VCL.FlexCel.Core, FlexCel.XlsAdapter, FlexCel.Render;
...
procedure ExportToPdf(const InFile, OutFile: string);
var
xls: TXlsFile;
pdf: TFlexCelPdfExport;
begin
xls := TXlsFile.Create(InFile);
try
pdf := TFlexCelPdfExport.Create(xls, true);
try
pdf.Export(OutFile);
finally
pdf.Free;
end;
finally
xls.Free;
end;
end;

65.Exporting a file to html

uses ..., VCL.FlexCel.Core, FlexCel.XlsAdapter, FlexCel.Render;
...
procedure ExportToHtml(const InFile, OutFile: string);
var
xls: TXlsFile;
html: TFlexCelHtmlExport;
begin
xls := TXlsFile.Create(InFile);
try
html := TFlexCelHtmlExport.Create(xls, true);
try
html.Export(OutFile, '');
finally
html.Free;
end;
finally
xls.Free;
end;
end;

6.使用Reprot Temple

6.1数据层

变量<#ReportVarName>
用户定义函数<#NumbertoString(2)>
数据集<#Dataset.myfield>
TList<T>和TArray<T>TFlexCelReport.AddTable<TyouType>("name",youtyupe)
直接SQL
虚拟Datasets

7.TList<T> and TArray<T> based DataSources

TMyObject = class
private
FFirstName: String;
FLastName: String;
public
property FirstName: String read FFirstName;
property LastName: String read FLastName;
end;
MyObjectList := TList<TMyObject>.Create;

您可以使用以下行将此集合添加为报表的数据源:

TFlexCelReport. AddTable<TMyObject>('MyName',Objs)

然后在模板中写入<#MyName.FirstName>和<#MyName.LastName>在“__MyName__”范围内导出集合

8.Dataset based DataSources



TFlexCelReport.AddTable('name_in_template', DataSet)

9.FlexCel Report设计指南

Tags<#tagName> and<#tagName(param1;param2)

Band设定"公式"->"名称管理器"

创建一个Band on A1:C1, we would go to the “Formulas” tab, then choose “Name Manager”:


Once there, we can define a Band __Customer__ on cells A1:C1. And once the name is defined,
we can easily see it on the Names combo:

注意范围名称开头和结尾的__。我们用它来指示FlexCel这是一个向下插入整行的水平范围。名称(Customer)的其余部分应该是存量数据源(表、数据数组等)的名称,或者是配置表上定义的自定义表

Range Types:

“__”Range:此范围向下移动并插入完整行。例如,要定义为数据集“客户”的每条记录向下插入完整行的带,您将使用名称__Customer__

•“_”Range:此范围类似于“__”,但范围之外的单元格不会向下移动。要定义仅为数据集“客户”的每条记录向下插入单元格范围的带,您将使用名称_Customer_

•“II_”Range:此范围向右移动并插入完整列。请注意,第一个字符是字母i,而不是管道(|)。要定义为数据集“客户”的每条记录插入完整列的带,您将使用名称II_Customer_II

•“I_”Range:此范围类似于“II_”,但范围之外的单元格不会向右移动。要为数据集“客户”的每条记录定义向右插入单元格的带,您将使用名称I_Customer_I

10.Master-detail

在下面的示例中,黄色单元格是区域"__Customer__",蓝色单元格是区域"__Orders__"

运行后效果

“X” ranges

"__Item__X”加了X之后会自动删除掉项目与总结之间的一个空行.

Fixed Bands

“__TopOrders__FIXED”的范围,它不会插入任何记录。有关详细信息,请参阅带有数据集的固定表单演示

Fixed “N” Bands

有时,您可能希望记录覆盖前n个单元格(如在“固定”带中),但在这些行被覆盖后,插入其余记录(如在普通报告中)。您可以通过使用“FixedN”范围来实现这一点,其中“N”是您希望固定的行数或列数。例如,“__data__FIXED2__”将覆盖前2行,并为其余行插入(data. RecordCount-2)行。您可以在平衡列演示中看到固定带的示例。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: TMS Flexcel是一种强大而灵活的软件工具,用于在Delphi和C ++ Builder等开发环境中创建和处理Excel文件。TMS Flexcel具有丰富的特性和功能,可以帮助开发人员在应用程序中轻松地生成和操作Excel文档。 首先,TMS Flexcel允许开发人员创建具有各种格式、样式和图表的Excel文件。开发人员可以使用TMS Flexcel提供的丰富的API来设置单元格的格式、字体、边框等属性,还可以创建各种类型的图表来展示数据。这样,开发人员可以根据需求创建出具有专业外观的Excel文件,提高应用程序的用户体验。 其次,TMS Flexcel还提供了丰富的数据处理功能。开发人员可以使用TMS Flexcel来读取和写入Excel文件中的数据,还可以对数据进行排序、筛选、求和等操作。此外,TMS Flexcel还支持公式计算,开发人员可以使用公式来进行复杂的数据处理和计算。 此外,TMS Flexcel还具有跨平台的特性。开发人员可以在不同的操作系统上使用TMS Flexcel来生成和处理Excel文件,例如Windows、Mac和Linux等。这为开发人员提供了更大的灵活性和多样性,可以在不同的开发环境和平台上使用TMS Flexcel来满足不同的需求。 总之,TMS Flexcel是一个功能强大、灵活且跨平台的软件工具,可以帮助开发人员轻松地生成和处理Excel文件。它提供了丰富的特性和功能,使开发人员能够创建具有专业外观的Excel文件,并对数据进行各种处理和计算。无论在哪个平台上,TMS Flexcel都能够提供高性能和稳定的表现,是开发人员不可或缺的工具之一。 ### 回答2: TMS FlexCel是一款用于创建、读取和修改Excel文件的强大组件库。它提供了丰富的功能和灵活的API,使开发人员能够轻松地操作和控制Excel文件。 TMS FlexCel支持各种Excel文件格式,包括XLSX、XLS、和CSV等。它可以从头开始创建新的Excel文件,也可以从现有文件中读取和修改数据。通过灵活的API,开发人员可以在Excel文件中添加、删除和移动工作表,插入图片、图表和公式,并设置单元格的样式和格式。 TMS FlexCel还支持导出数据到不同的格式,如PDF和HTML。开发人员可以利用其强大的导出功能,将Excel数据转换为其他格式,并在各种平台和设备上显示和共享。 此外,TMS FlexCel还提供了丰富的文档和示例,以帮助开发人员快速上手和理解其功能和用法。它支持多种开发环境和平台,如Delphi、.NET和JavaScript等,使开发人员能够在不同的项目中灵活使用。 总之,TMS FlexCel是一款功能强大且易于使用的Excel组件库,为开发人员提供了灵活的操作和控制Excel文件的能力,帮助他们快速开发出高质量的Excel应用程序。 ### 回答3: TMS FlexCel是一种功能强大且灵活的电子表格组件,用于在Delphi和.NET开发环境中处理和生成电子表格文件。它允许开发人员通过编程方式创建、修改和读取Excel文件,还可以将数据导出到Excel、PDF、HTML和其他格式中。 TMS FlexCel具有很多有用的功能。首先,它支持几乎所有Excel文件格式,包括xlsx、xls和CSV等。这意味着开发人员可以轻松地与Excel文件进行交互,而无需额外处理。其次,它提供了丰富的API,允许开发人员对电子表格中的单元格、行、列和工作表进行操作。例如,可以通过代码自动填充数据、格式化单元格、创建图表和添加公式等。此外,TMS FlexCel还支持合并和拆分单元格、保护工作表和设置打印选项等功能。 除了基本的电子表格功能外,TMS FlexCel还提供了一些高级功能。例如,它允许开发人员生成报表和标签,执行数据筛选和排序,并支持多语言文本和国际化。此外,TMS FlexCel还支持复杂的数据绑定,可以将数据库或其他数据源与电子表格中的单元格关联起来。这样,当数据源发生变化时,电子表格中的数据也会自动更新。 总之,TMS FlexCel是一个功能强大、易于使用的电子表格组件,非常适合开发人员在Delphi和.NET平台上处理和生成Excel文件。它为开发人员提供了许多有用的功能和灵活性,使其成为开发商业应用和生成报告的理想选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蝈蝈(GuoGuo)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值