TXLSReadWriteII2 读取数据
TXLSReadWriteII2 按行读取数据(写得复杂了点,实际项目中的,可以自己简化)
procedure TformMain.LoadGeneralObject(_type, _col, _row: Integer; _filename: AnsiString);
var
xls: TXLSReadWriteII2;
i: integer;
dataRec: TDataRec;
reportedRec: TReportedRec;
RegistrationNO: AnsiString;
StartstopTime: AnsiString;
LastTime: AnsiString;
Ownedcompanies: AnsiString;
SimNO: AnsiString;
TerminalIDHex: AnsiString;
TerminalIDStr: AnsiString;
begin
RzProgressBar1.Percent := 0;
i := 0;
xls := TXLSReadWriteII2.Create(Self);
try
Xls.Filename := _filename;
Xls.Read; //必须的
Xls.Sheet[0].LastCol := _col;
Xls.Sheet[0].LastRow := _row;
case _type of
1: i := 1;
2: i := 2;
end;
while i <= Xls.Sheet[0].LastRow do
begin
case _type of
1:
begin
reportedRec.ID := StrToIntDef(XLS.Sheets[0].AsFmtString[0, i], 0);
Ownedcompanies := XLS.Sheets[0].AsFmtString[1, i];
reportedRec.Ownedcompanies := FilterChar(Ownedcompanies);
RegistrationNO := XLS.Sheets[0].AsFmtString[2, i];
reportedRec.RegistrationNO := Q_StrTok1(RegistrationNO, '-');
reportedRec.Industry := FilterChar(XLS.Sheets[0].AsFmtString[3, i]);
reportedRec.Dealer := FilterChar(XLS.Sheets[0].AsFmtString[4, i]);
reportedRec.SimNO := FilterChar(XLS.Sheets[0].AsFmtString[6, i]);
reportedRec.TerminalFactory := FilterChar(XLS.Sheets[0].AsFmtString[7, i]);
TerminalIDHex := FilterChar(XLS.Sheets[0].AsFmtString[8, i]);
TerminalIDStr := Trim(Q_StrTok1(TerminalIDHex, '/'));
reportedRec.TerminalIDInt := StrToInt64Def(TerminalIDStr, 0);
TerminalIDHex := Trim(TerminalIDHex);
Q_Delete(TerminalIDHex, 1, 2);
reportedRec.TerminalIDHex := TerminalIDHex;
reportedRec.Reported := XLS.Sheets[0].AsFmtString[9, i] = '已上报';
reportedRec.isReported := True;
AddReportInfo(reportedRec);
inc(i, 2);
end;
2:
begin
dataRec.ID := StrToIntDef(XLS.Sheets[0].AsFmtString[0, i], 0);
dataRec.VendorID := StrToIntDef(XLS.Sheets[0].AsFmtString[1, i], 0);
dataRec.TerminalIDHex := XLS.Sheets[0].AsFmtString[2, i];
TerminalIDStr := XLS.Sheets[0].AsFmtString[3, i];
dataRec.TerminalIDInt := StrToIntDef(TerminalIDStr, 0);
dataRec.TerminalKind := IfThen(Q_CopyLeft(TerminalIDStr, 1) = '4', 600, 700);
dataRec.CenterID := StrToIntDef(XLS.Sheets[0].AsFmtString[4, i], 0);
dataRec.CommType := XLS.Sheets[0].AsFmtString[5, i];
Ownedcompanies := XLS.Sheets[0].AsFmtString[6, i];
dataRec.Ownedcompanies := FilterChar(Ownedcompanies);
RegistrationNO := XLS.Sheets[0].AsFmtString[7, i];
if Trim(RegistrationNO) = '' then
dataRec.RegistrationNO := ''
else
dataRec.RegistrationNO := Q_StrTok1(RegistrationNO, '-');
SimNO := XLS.Sheets[0].AsFmtString[8, i];
dataRec.SimNO := FilterChar(SimNO);
dataRec.Reported := XLS.Sheets[0].AsFmtString[13, i] = '√';
dataRec.BackInfo := XLS.Sheets[0].AsFmtString[14, i] = '√';
StartstopTime := XLS.Sheets[0].AsFmtString[15, i];
if StartstopTime = '' then
begin
dataRec.StartstopTime := '';
dataRec.LastTime := 0;
end
else
begin
StartstopTime := FilterChar(StartstopTime);
dataRec.StartstopTime := StartstopTime;
Q_StrTok1(StartstopTime, '~');
LastTime := FormatDateTime('yyyy-', Now) + StartstopTime;
dataRec.LastTime := StrToDateTime(LastTime);
end;
dataRec.RealTime := 0;
AddCarGeneralInfo(dataRec);
inc(i);
end;
end;
doOnProgressBar(100 * i div Xls.Sheet[0].LastRow);
end;
finally
xls.Free;
end;
end;
TXLSReadWriteII2 读取数据的更多相关文章
- struts2中从后台读取数据到<s:select>
看到网上好多有struts2中从后台读取数据到<s:select>的,但都 不太详细,可能是我自己理解不了吧!所以我自己做了 一个,其中可能 有很多不好的地方,望广大网友指出 结果如图 p ...
- [MVC4]ASP.NET MVC4+EF5(Lambda/Linq)读取数据
继续上一节初始ASP.NET MVC4,继续深入学习,感受了一下微软的MVC4+EF5(EntityFramework5)框架的强大,能够高效的开发出网站应用开发系统,下面就看一下如何用MVC4+EF ...
- ubuntu server 12.04U盘安装,提示无法挂载安装光盘或光盘读取数据出错
今天用Ultraiso将Ubuntu server 12.04 刻入U盘中安装系统,中间提示错误:1.检测不到cdrom(即U盘没有挂载上):2.从光盘中读取数据出错.问题如下图所示: 上网搜了下解决 ...
- MySQL数据库中tinyint类型字段读取数据为true和false
今天遇到这么一个问题,公司最近在做一个活动,然后数据库需要建表,其中有个字段是关于奖励发放的状态的字段,结果读取出来的值为true 一.解决读取数据为true/false的问题 场景: 字段:stat ...
- My Game --文件读取数据
My Game --线段数据 中说到背景的绘制由贝赛尔曲线生成线段,用 DrawNode 画多边形,同时一张背景有两座山,一座山有两条以上贝赛尔曲线保存,用了嵌套的数据类:Bezier,LineLay ...
- Java—从文件中读取数据
1.FileInputStream() // 构建字节输入流对象,参数为文件名 FileInputStream fin = new FileInputStream("message" ...
- 10天学会phpWeChat——第三天:从数据库读取数据到视图
在第二天,我们创建了我们的第一个phpWeChat功能模块,但是比较简单.实际生产环境中,我们不可能有如此简单的需求.更多的情况是数据存储在MySql数据库中,我们开发功能模块的作用就是将这些数据从M ...
- 用EXCEL内嵌的Visual Basic for Application 编程,通过 UGSimple USB-GPIB 控制器来驱动仪器34401A,并从34401A读取数据
现在市场上有很多中USB-GPIB 控制器,或叫 USB 转GPIB链接线. 每种GPIB控制器都有它的 函数库(dll库).各种GPIB 控制器的价钱插别很大.这里以一种价钱较便宜的USB-GPIB ...
- winform 异步读取数据 小实例
这几天对突然对委托事件,异步编程产生了兴趣,大量阅读前辈们的代码后自己总结了一下. 主要是实现 DataTable的导入导出,当然可以模拟从数据库读取大量数据,这可能需要一定的时间,然后 再把数据导入 ...
随机推荐
- Mysql 杀死sleep进程
查询数据库当前设置的最大连接数:查看mysql数据库连接数.并发数相关信息 show global variables like '%max_connections%'; 查看mysql连接数:my ...
- maven项目pom.xml第一行报错
maven项目pom.xml第一行报错 这是第一行:<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi= ...
- leetcode 421.Maximum XOR of Two Numbers in an Array
题目中给定若干个数,然后任意选定两个数使得其异或值最大. 先利用样例中的: 3 10 5 25 2 8 这些数转换为二进制来看的话那么是先找到最高位的1然后与数组中其他的数相与后的数值保存到set中去 ...
- Javascript 2.3
声明多个变量用逗号隔开 var teacher=30,stu=40; Javascript变量允许包含 美元符号 $
- 编译Linux-4.15.1内核时遇到:“error : openssl/bio.h :No such file or folder”
如题: scripts/extract-cert.c::: fatal error: openssl/bio.h: No such file or directory compilation term ...
- pycharm 在线激活
1.在pycharm过期页面选择 enter License 2.激活界面的License server输入:http://idea.liyang.io 然后点击激活 (确保电脑能上网,亲测有效)
- 第三章泛型集合ArrayList 和Hashtable
第三章泛型集集合 ArrayList 变量名 = new ArrayList(); //相当与一个容器 他的执行using 是 using System.Collections; 变量名.ADD( ...
- listagg乱码问题
listagg(to_char(ts.tsmc),',') within GROUP (order by xs.xh) ,先将字段to_char 以后,就可以解决
- NumPy-快速处理数据--ndarray对象--数组的创建和存取
本文摘自<用Python做科学计算>,版权归原作者所有. NumPy为Python提供了快速的多维数组处理的能力,而SciPy则在NumPy基础上添加了众多的科学计算所需的各种工具包,有了 ...
- 阅读 video on-screen display v6.0笔记
阅读 video on-screen display v6.0笔记 关于axi总线时钟的区分 需要弄清楚的是aclk, aclken, aresetn 信号是和video 有关的,axi4-lite的 ...