uniGUI试用笔记(七)
2024-10-14 00:52:10
uniGUI的文件下载由于TUniSession的存在而变得非常简单,最典型的一个例子就是将列表中的所有数据导出到Excel中。服务器上采用TMS FlexCel控件,先将数据集中的记录导入到Excel文件中,然后再将Excel文件内容输出到内存流中,最后通过TUniSession发送到客户端。代码如下:
procedure TfmeWebDBListBase.ExportData;
var
i, rowindex, colindex: Integer;
ms : TMemoryStream;
begin
{ 检查数据集 }
if Assigned(cdsMain) and cdsMain.Active then
try
{ 创建Excel文件 }
FlexCelImport1.NewFile();
cdsMain.First;
{ 第一行为标题 }
rowindex := ;
colindex := ;
for i := to cdsMain.FieldCount - do
{ 只导出数据集中可视的字段 }
if cdsMain.Fields[i].Visible then
begin
FlexCelImport1.CellValue[rowindex, colindex] := cdsMain.Fields[i].DisplayLabel;
inc(colindex);
end;
{ 依次导出数据 }
while not cdsMain.Eof do
begin
{ 增加一行 }
inc(rowindex);
colindex := ;
for i := to cdsMain.FieldCount - do
{ 只导出数据集中可视的字段 }
if cdsMain.Fields[i].Visible then
begin
{ 时间和日期字段需要单独出来一下,否则出来的都是浮点数 }
if cdsMain.Fields[i].DataType in [ftDate, ftDateTime, ftTime, ftTimeStamp] then
FlexCelImport1.CellValue[rowindex, colindex] := cdsMain.Fields[i].AsString
else
FlexCelImport1.CellValue[rowindex, colindex] := cdsMain.Fields[i].Value;
inc(colindex);
end;
{ 下一条 }
cdsMain.Next;
end; { 创建内存流 }
ms := TMemoryStream.Create;
try
{ 将Excel保存到内存流 }
FlexCelImport1.SaveToStream(ms);
ms.Position := ;
{ 将数据流发送到客户端,同时指定下载文件名,非常简单 }
MainForm.uniApplication.UniSession.SendStream(
ms, ModelName + '.xls' );
finally
ms.Free;
{ 清理内存 }
FlexCelImport1.CloseFile;
end;
except
on E : Exception do
FlexCelImport1.CloseFile;
end;
end;
最新文章
- java深入技术九 (注解)
- Android(Linux)控制GPIO方法二
- 在IntelliJ IDEA中添加框架支持时找不到Hibernate的解决办法
- iOS 页面间几种传值方式(属性,代理,block,单例,通知)
- 关于原生的Javascript
- 模拟Select-Options对象实现多项数据输入功能
- 名词释义(ActiveMQ 和 Webservice)
- win7刷新图标缓存
- SecureCRT上传、下载文件 使用sz与rz命令
- mac 布置 git仓库服务器
- Android记录4--自定义ToggleButton+用SharedPreferences保存用户配置
- 【HDU 5808】 Price List Strike Back (整体二分+动态规划)
- Robot Framework学习笔记(九)------创建资源和用户关键字
- 解决tomcat部署项目中碰到的几个问题
- redis-win-server 正确启动方式
- select2的用法
- spring boot项目使用外部tomcat启动失败总结
- one order 理解
- Java开发工程师基础Math,Random,Scanner类的使用
- Servet3.0于Servlet2.5比较