张志峰的博客

水滴石川,积少成多。

导航

Delphi TXLSReadWriteII2 读取数据

Posted on 2012-06-13 09:06  ╰★张志峰★╮  阅读(1913)  评论(0编辑  收藏  举报

 

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;