⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qexport4xlsutils.pas

📁 Advanced.Export.Component.v4.01.rar,delphi 第三方控件
💻 PAS
📖 第 1 页 / 共 2 页
字号:
    if (Int(d) = d) and (d <= Mask) and (d >= - Mask - 1) then begin  //Type 1-3: 30 bits integer
      RK := Round(d) shl 2 + i + 2;
      Exit;
    end;
  end;

  Result := false;
end;

function GetStrLen(IsWide: boolean; Data: PByteArray; Position: integer;
  UseExtStrLen: boolean; ExtStrLen: integer{longword}): integer{int64};
var
  L, rt: Cardinal;
  bsize: byte;
  sz: cardinal;
  P: integer;
  OptionFlags: byte;
begin
  P := Position;
  if UseExtStrLen then
    L := ExtStrLen
  else begin
    if IsWide then begin
      L := GetWord(Data, P);
      Inc(P, 2);
    end
    else begin
      L := Data^[P];
      Inc(P);
    end;
  end;

  OptionFlags := Data^[P];
  Inc(P);

  bsize := OptionFlags and $1;

  rt := 0;
  if (OptionFlags and $8) = $8 then begin //RTF Info
    rt := GetWord(Data, P);
    Inc(P, 2);
  end;

  sz := 0;
  if (OptionFlags and $4) = $4 then begin //Far East Info
    sz := GetInteger(Data, P);
    Inc(P, 4);
  end;
  {$IFNDEF VCL4}
  Result := {int64}integer(P - Position) + l shl bsize + rt shl 2 + sz;
  {$ELSE}
  Result := int64(P - Position) + l shl bsize + rt shl 2 + sz;
  {$ENDIF}
end;

function ErrCodeToString(ErrCode: integer): WideString;
begin
  case ErrCode of
    BOOL_ERR_ID_NULL    : Result := BOOL_ERR_STR_NULL;
    BOOL_ERR_ID_DIV_ZERO: Result := BOOL_ERR_STR_DIV_ZERO;
    BOOL_ERR_ID_VALUE   : Result := BOOL_ERR_STR_VALUE;
    BOOL_ERR_ID_REF     : Result := BOOL_ERR_STR_REF;
    BOOL_ERR_ID_NAME    : Result := BOOL_ERR_STR_NAME;
    BOOL_ERR_ID_NUM     : Result := BOOL_ERR_STR_NUM;
    BOOL_ERR_ID_NA      : Result := BOOL_ERR_STR_NA;
    else Result := BOOL_ERR_STR_NULL;
  end;
end;

function StringToErrCode(const ErrStr: WideString): integer;
begin
  if ErrStr = BOOL_ERR_STR_NULL then Result := BOOL_ERR_ID_NULL
  else if ErrStr = BOOL_ERR_STR_DIV_ZERO then Result := BOOL_ERR_ID_DIV_ZERO
  else if ErrStr = BOOL_ERR_STR_VALUE then Result := BOOL_ERR_ID_VALUE
  else if ErrStr = BOOL_ERR_STR_REF then Result := BOOL_ERR_ID_REF
  else if ErrStr = BOOL_ERR_STR_NAME then Result := BOOL_ERR_ID_NAME
  else if ErrStr = BOOL_ERR_STR_NUM then Result := BOOL_ERR_ID_NUM
  else if ErrStr = BOOL_ERR_STR_NA then Result := BOOL_ERR_ID_NA
  else raise ExlsFileError.CreateFmt(sInvalidErrStr, [ErrStr]);
end;

function Col2Letter(Col: integer): string;
var
  n, m, c: integer;
begin
  c := Col - 1;
  Result := EmptyStr;
  n := c div 26;
  m := c mod 26;
  if n > 0 then Result := Result + Copy(LETTERS, n, 1);
  Result := Result + Copy(LETTERS, m + 1, 1);
end;

function Row2Number(Row: integer): string;
begin
  Result := IntToStr(Row);
end;

function Letter2Col(Letter: string): integer;
var
  i: integer;
begin
  Result := 0;
  if Letter = EmptyStr then Exit;
  for i := 1 to Length(Letter) - 1 do
    Result := Result + Pos(Letter[i], LETTERS) * Trunc(Power(26, i));
  Result := Result + Pos(Letter[Length(Letter)], LETTERS);
end;

function Number2Row(Number: string): integer;
begin
  Result := StrToInt(Number);
end;

function LoadRecord(Section: TxlsSection; Stream: TStream;
  Header: TBIFF_Header): TbiffRecord;
var
  Data: PByteArray;
  R: TbiffRecord;
  NextRecordHeader: TBIFF_Header;
begin
  GetMem(Data, Header.Length);
  try
    if Stream.Read(Data^, Header.Length) <> Header.Length then
      raise Exception.Create(sExcelInvalid);
  except
    FreeMem(Data);
    raise;
  end;

  case Header.ID of
    BIFF_BOF       :
      R := TbiffBOF.Create(Section, Header.ID, Header.Length, Data);
    BIFF_EOF       :
      R := TbiffEOF.Create(Section, Header.ID, Header.Length, Data);
    BIFF_FORMULA   :
      R := TbiffFormula.Create(Section, Header.ID, Header.Length, Data);
    BIFF_SHRFMLA   :
      R := TbiffShrFmla.Create(Section, Header.ID, Header.Length, Data);

    {xlr_OBJ         : R:= TObjRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_MSODRAWING  : R:= TDrawingRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_MSODRAWINGGROUP
                    : R:= TDrawingGroupRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_TXO         : R:= TTXORecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_NOTE        : R:= TNoteRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_RECALCID,   //So the workbook gets recalculated
    xlr_EXTSST,     // We will have to generate this again
    xlr_DBCELL,     //To find rows in blocks... we need to calculate it again
    xlr_INDEX,      //Same as DBCELL
    xlr_MSODRAWINGSELECTION,   // Object selection. We do not need to select any drawing
    xlr_DIMENSIONS  //Used range of a sheet
                    : R:= TIgnoreRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);}
    BIFF_SST       :
      R := TbiffSST.Create(Section, Header.ID, Header.Length, Data);
    BIFF_BOUNDSHEET:
      R := TbiffBoundSheet.Create(Section, Header.ID, Header.Length, Data);

    //xlr_Array       : R:= TCellRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    BIFF_BLANK     :
      R := TbiffBlank.Create(Section, Header.ID, Header.Length, Data);
    BIFF_BOOLERR   :
      R := TbiffBoolErr.Create(Section, Header.ID, Header.Length, Data);
    BIFF_NUMBER    :
      R := TbiffNumber.Create(Section, Header.ID, Header.Length, Data);
    BIFF_MULBLANK  :
      R := TbiffMulBlank.Create(Section, Header.ID, Header.Length, Data);
    BIFF_MULRK     :
      R := TbiffMulRK.Create(Section, Header.ID, Header.Length, Data);
    BIFF_RK        :
      R := TbiffRK.Create(Section, Header.ID, Header.Length, Data);
    BIFF_STRING    :
      R:= TbiffString.Create(Section, Header.ID, Header.Length, Data);
    BIFF_XF        :
      R := TbiffXF.Create(Section, Header.ID, Header.Length, Data);
//    xlr_FONT        : R:= TFontRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    BIFF_FORMAT    :
      R := TbiffFormat.Create(Section, Header.ID, Header.Length, Data);
{    xlr_Palette     : R:= TPaletteRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_Style       : R:= TStyleRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);}

    BIFF_LABELSST  :
      R := TbiffLabelSST.Create(Section, Header.ID, Header.Length, Data);
//    xlr_Row         : R:= TRowRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    BIFF_NAME      : R := TbiffName.Create(Section, Header.ID, Header.Length, Data);
{    xlr_TABLE       : R:= TTableRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_CELLMERGING : R:= TCellMergingRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_CONDFMT     : R:= TCondFmtRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_CF          : R:= TCFRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_DVAL        : R:= TDValRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);}
    BIFF_CONTINUE  :
      R := TbiffContinue.Create(Section, Header.ID, Header.Length, Data);

{    xlr_XCT,        // Cached values of a external workbook... not supported yet
    xlr_CRN         // Cached values also
                    : R:=TIgnoreRecord.Create(RecordHeader.Id, Data, RecordHeader.Size); //raise Exception.Create (ErrExtRefsNotSupported);
    xlr_SUPBOOK     : R:= TSupBookRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_EXTERNSHEET : R:= TExternSheetRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_ChartAI     : R:= TChartAIRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_Window1     : R:= TWindow1Record.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_Window2     : R:= TWindow2Record.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_HORIZONTALPAGEBREAKS: R:= THPageBreakRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_COLINFO     : R:= TColInfoRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_DEFCOLWIDTH : R:= TDefColWidthRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);
    xlr_DEFAULTROWHEIGHT: R:= TDefRowHeightRecord.Create(RecordHeader.Id, Data, RecordHeader.Size);

    xlr_FILEPASS: raise Exception.Create(ErrFileIsPasswordProtected);}

    else R := TbiffRecord.Create(Section, Header.ID, Header.Length, Data);
  end;

  //Peek at the next record...
  if Stream.Read(NextRecordHeader, SizeOf(NextRecordHeader))=
     SizeOf(NextRecordHeader) then begin
    if NextRecordHeader.ID = BIFF_CONTINUE then
      R.AddContinue(LoadRecord(Section, Stream, NextRecordHeader) as TbiffContinue)
    {else if NextRecordHeader.ID = BIFF_TABLE then
      if (R is TFormulaRecord) then
      begin
        (R as TFormulaRecord).TableRecord:=LoadRecord(DataStream, NextRecordHeader) as TTableRecord;
      end
      else Exception.Create(ErrExcelInvalid)}
    else begin
      if NextRecordHeader.ID = BIFF_STRING then
        if not (R is TbiffFormula) and not (R is TbiffShrFmla) {and
           not (R is TTableRecord)} then
          raise ExlsFileError.Create(sExcelInvalid);
      Stream.Seek(-SizeOf(NextRecordHeader), soFromCurrent);
    end;
  end;

  Result := R;
end;

procedure WriteMSOHeader(FBT, Version, Instance: word; Length: integer;
  Stream: TStream);
var
  Header: TMSO_Header;
begin
  Header.Options := Version + (Instance shl 4);
  Header.FBT := FBT;
  Header.Length := Length;
  Stream.Write(Header, SizeOf(TMSO_Header));
end;

procedure WriteMSOHeaderToByteArray(FBT, Version, Instance: word;
  Length: integer; ByteArray: PByteArray; var Position: integer);
var
  Header: TMSO_Header;
begin
  Header.Options := Version + (Instance shl 4);
  Header.FBT := FBT;
  Header.Length := Length;
  Move(Header, ByteArray[Position], SizeOf(TMSO_Header));
  Inc(Position, SizeOf(TMSO_Header));
end;

function CreateXLSStream(const FileName: string; var Storage: IStorage;
  var Stream: IStream): TStream;
var
  WC: PWideChar;
begin
  GetMem(WC, 512);
  try
    WC := StringToWideChar(FileName, WC, 512);
    OleCheck(StgCreateDocfile(WC, STGM_DIRECT or STGM_READWRITE or
      STGM_CREATE or STGM_SHARE_EXCLUSIVE, 0, Storage));
  finally
    FreeMem(WC);
  end;
  OleCheck(Storage.CreateStream('Workbook', STGM_DIRECT or STGM_READWRITE or
    STGM_CREATE or STGM_SHARE_EXCLUSIVE, 0, 0, Stream));
  Result := TOleStream.Create(Stream);
end;

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -