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)行。您可以在平衡列演示中看到固定带的示例。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/571582.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯-单片机基础9——基于2023年官方onewire通信代码外设讲解(温度传感器DS18B20)

蓝桥杯单片机组备赛指南请查看这篇文章&#xff1a;戳此跳转蓝桥杯备赛指南文章 本文章针对蓝桥杯-单片机组比赛开发板所写&#xff0c;代码可直接在比赛开发板上使用。 型号&#xff1a;国信天长4T开发板&#xff08;绿板&#xff09;&#xff0c;芯片&#xff1a;IAP15F2K6…

第2章. 揭秘指令提示技术,轻松驾驭Chatgpt

Chatgpt的指令提示 想获取Chatgpt的高质文本&#xff1f;试试指令提示吧&#xff01;为模型指明方向&#xff0c;它就能产出我们心仪的内容。 指令提示技术&#xff0c;就是给Chatgpt一个明确的指引。想让它输出什么&#xff0c;只需简单告诉它。 提示公式&#xff1a;按这个…

弹性伸缩 AS

&#x1f341;博主简介&#xff1a; &#x1f3c5;云计算领域优质创作者 &#x1f3c5;2022年CSDN新星计划python赛道第一名 &#x1f3c5;2022年CSDN原力计划优质作者 &#x1f3c5;阿里云ACE认证高级工程师 &#x1f3c5;阿里云开发者社区专…

第1章 实时3D渲染流水线

前言 本书所剖析的Unity 3D内置着色器代码版本是2017.2.0f3&#xff0c;读者可以从Unity 3D官网下载这些着色器代码。这些代码以名为builtin_shaders-2017.2.0f3.zip的压缩包的形式提供&#xff0c;解压缩后&#xff0c;内有4个目录和1个license.txt文件。 目录CGIncludes存放了…

python3字典的排序

创建一个字典 dict1{a:2,b:3,c:8,d:4} 1、分别取键、值 取字典的所有键&#xff0c;所有的值&#xff0c;利用dict1.keys()&#xff0c;dict1.vaules()&#xff0c; 由于键&#xff0c;值有很多个&#xff0c;所以要加s&#xff0c;另外注意这里要加括号&#xff0c;这样的小…

python3怎么下载

百度搜索“python官网”。 点击进入官网&#xff0c;如图所示&#xff1a; 依次点击“Download”-“windows”。 如图会出现下载选项&#xff0c;根据电脑情况选择&#xff0c;这里我选择64位的。 选择executable版进行安装。 至此下载完成。

小程序接入第三方信息流流程 下载SDK

由第三方信息流提供相应的SDK下载链接以及接入说明和开发文档或其他方式接入&#xff0c;如果第三方能支持小程序SDK&#xff0c;则不需要后面步骤&#xff0c;只需要提供相关开发文档和接入方式接口 接入SDK 后台开发人员接入第三方提供的SDK&#xff0c;并进行相关接口开发…

鸿蒙OS开发案例:【API9】遍历沙漏文件夹并输入文件的大小

1.获取打印文件大小 /*** 获取打印文件大小*/static getFileSize(byteNum: number) {if (byteNum < 0) {return "shouldnt be less than zero!";} else if (byteNum < 1024) {return ${byteNum.toFixed(3)}B;} else if (byteNum < 1048576) {return (byteNu…

pt-archiver的实践分享,及为何要用 ob-archiver 归档数据的探讨

作者简介&#xff1a;肖杨&#xff0c;软件开发工程师 在数据密集型业务场景中&#xff0c;数据管理策略是否有效至关重要&#xff0c;它直接关系到系统性能与存储效率的提升。数据归档作为该策略的关键环节&#xff0c;不仅有助于优化数据库性能&#xff0c;还能有效降低存储成…

四川宏博蓬达法律咨询有限公司:法律服务的典范,值得信赖的合作伙伴

在当今社会&#xff0c;法律服务已经成为人们生活中不可或缺的一部分。无论是个人还是企业&#xff0c;都可能遇到各种法律问题&#xff0c;需要专业的法律机构来提供支持和帮助。四川宏博蓬达法律咨询有限公司就是在这样的背景下应运而生&#xff0c;成为众多客户信赖的法律服…

07、Lua 流程控制

Lua 流程控制 Lua 流程控制控制结构语句 Lua 流程控制 Lua编程语言流程控制语句通过程序设定一个或多个条件语句来设定。在条件为 true 时执行指定程序代码&#xff0c;在条件为 false 时执行其他指定代码。 以下是典型的流程控制流程图&#xff1a; 控制结构的条件表达式结…

【最新!红外小目标检测算法HCFNet】

文章目录 摘要1 引言2 相关工作2.1 传统方法2.2 深度学习方法 3 方法3.1 PPA3.2 维度感知选择性整合模块3.3 多稀释通道细化器模块3.4 损失函数设计 4 实验4.1 数据集与评估指标4.2 实现细节4.3 消融和对比 5 结论 论文&#xff1a;HCF-Net: Hierarchical Context Fusion Netwo…