fpreportdatacsv.pp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. {
  2. This file is part of the Free Pascal run time library.
  3. Copyright (c) 1999-2022 by Michael van Canneyt and other members of the
  4. Free Pascal development team
  5. report data csv
  6. See the file COPYING.FPC, included in this distribution,
  7. for details about the copyright.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  11. **********************************************************************}
  12. {$IFNDEF FPC_DOTTEDUNITS}
  13. unit fpreportdatacsv;
  14. {$ENDIF FPC_DOTTEDUNITS}
  15. {$mode objfpc}{$H+}
  16. interface
  17. {$IFDEF FPC_DOTTEDUNITS}
  18. uses
  19. System.Classes, System.SysUtils, Data.Db, Data.BufDataset, Data.CsvDataset, FpJson.Data, FpReport.Data;
  20. {$ELSE FPC_DOTTEDUNITS}
  21. uses
  22. Classes, SysUtils, db, bufdataset, csvdataset, fpjson, fpreportdata;
  23. {$ENDIF FPC_DOTTEDUNITS}
  24. Const
  25. keyFileName = 'filename';
  26. keyFirstLineHasFieldNames = 'firstLineHasFieldNames';
  27. keyCustomFieldNames = 'customFieldNames';
  28. keyDelimiter = 'delimiter';
  29. keyQuoteChar = 'quoteChar';
  30. DefFirstLineFieldNames = True;
  31. DefDelimiter = ',';
  32. DefQuoteChar = '"';
  33. Type
  34. TCSVReportDataHandler = Class(TFPReportDataHandler)
  35. Function CreateDataset(AOwner : TComponent; AConfig : TJSONObject) : TDataset; override;
  36. Class Function CheckConfig(AConfig: TJSONObject): String; override;
  37. Class Function DataType : String; override;
  38. Class Function DataTypeDescription : String; override;
  39. end;
  40. Resourcestring
  41. SFileNameDoesNotExist = 'Filename does not exist: "%s"';
  42. SErrNeedFileName = 'Need a CSV file name';
  43. implementation
  44. { TCSVReportDataHandler }
  45. Type
  46. { TMyCSVDataset }
  47. TMyCSVDataset = Class(TCSVDataset)
  48. private
  49. FCSVFileName: String;
  50. Protected
  51. function GetPacketReader(const Format: TDataPacketFormat; const AStream: TStream): TDataPacketReader; override;
  52. Procedure InternalOpen; override;
  53. Public
  54. Property CSVFileName : String Read FCSVFileName Write FCSVFileName;
  55. end;
  56. { TMyCSVDataset }
  57. function TMyCSVDataset.GetPacketReader(const Format: TDataPacketFormat; const AStream: TStream): TDataPacketReader;
  58. begin
  59. Result:=inherited GetPacketReader(Format, AStream);
  60. if (Result is TCSVDataPacketReader) and (FieldDefs.Count>0) then
  61. TCSVDataPacketReader(Result).CreateFieldDefs:=FieldDefs;
  62. end;
  63. procedure TMyCSVDataset.InternalOpen;
  64. begin
  65. FileName:=CSVFileName;
  66. Inherited;
  67. FileName:='';
  68. end;
  69. function TCSVReportDataHandler.CreateDataset(AOwner: TComponent; AConfig: TJSONObject): TDataset;
  70. Var
  71. C : TMyCSVDataset;
  72. A : TJSONArray;
  73. I : Integer;
  74. begin
  75. C:=TMyCSVDataset.Create(AOWner);
  76. C.CSVOptions.FirstLineAsFieldNames:=AConfig.Get(keyFirstLineHasFieldNames,DefFirstLineFieldNames);
  77. C.CSVOptions.Delimiter:=AConfig.Get(KeyDelimiter,defDelimiter)[1];
  78. C.CSVOptions.quoteChar:=AConfig.Get(KeyQuoteChar,defQuoteChar)[1];
  79. if not C.CSVOptions.FirstLineAsFieldNames then
  80. begin
  81. A:=AConfig.Get(keyCustomFieldNames,TJSONArray(Nil));
  82. If Assigned(A) then
  83. For I:=0 to A.Count-1 do
  84. C.FieldDefs.Add(A.Strings[i],ftString,255);
  85. end;
  86. C.ReadOnly:=True;
  87. C.CSVFileName:=AConfig.Get(KeyFileName,'');
  88. Result:=C;
  89. end;
  90. class function TCSVReportDataHandler.CheckConfig(AConfig: TJSONObject): String;
  91. Var
  92. FN : UTF8String;
  93. begin
  94. Result:='';
  95. FN:=AConfig.Get(KeyFileName,'');
  96. if FN='' then
  97. Result:=SErrNeedFileName
  98. else if not FileExists(FN) then
  99. Result:=Format(SFileNameDoesNotExist,[FN]);
  100. end;
  101. class function TCSVReportDataHandler.DataType: String;
  102. begin
  103. Result:='CSV'
  104. end;
  105. class function TCSVReportDataHandler.DataTypeDescription: String;
  106. begin
  107. Result:='Comma-separated values text file';
  108. end;
  109. initialization
  110. TCSVReportDataHandler.RegisterHandler;
  111. end.