im 使用 Delphi 7 的 Crystal Reports VCL 运行 Delphi 的 Crystal Reports。我想从这个德尔福应用程序设置当前参数值。我正在成功发送数字或字符串参数的此值。但是现在我正在努力解决已将Allow Ranges
设置为True
的日期参数。
我得到的错误是:305:Error converting string to ValueInfo - ParamFields[2].CurrentValues.Add <StrToValueInfo>
正在使用这段代码,就像我说的那样,它不适用于没有范围参数。在下面的代码中,参数PARAM_DATE
是一个允许范围的日期参数。知道如何传递范围值吗?
procedure TReportFrame.btnExecuteReportClick(Sender: TObject);
var
Crpe1 : TCrpe;
varArr : variant;
i : integer;
a : TCrpeParamFieldRangesItem;
b : TCrpeParamFieldCurrentValuesItem;
begin
SetCurrentDir( GetCommonFilesPath );
try
Crpe1 := TCrpe.Create(Self);
Crpe1.DiscardSavedData();
Crpe1.ReportName := getReportBasePath() + reportFileName;
Crpe1.IgnoreKnownProblems := true;
Crpe1.LoadEngineOnUse := true;
Crpe1.Connect.Clear;
Crpe1.Tables[0].ConnectBuffer := glbDBMan.GetConnectionString;
Crpe1.ParamByName('PARAM_SORTING_TYPE', EmptyStr).CurrentValue := VarToStr( paramSposobSortowania.getSelectedValue());
varArr := parameterOsobaOdpowiedzialna.getSelectedValues();
for i := VarArrayLowBound(varArr,1) to VarArrayHighBound(varArr,1) do
begin
Crpe1.ParamByName('PARAM_PERSON', EmptyStr).CurrentValues.Add(VarToStr( varArr[i]));
end;
// Crpe1.ParamByName('PARAM_DATA_ZLOZENIA_WNIOSKU', EmptyStr).CurrentValues.Add('2012-4-1');
// a := TCrpeParamFieldRangesItem.Create;
// a.RangeStart := '2012-4-1';
// a.RangeEnd := '2012-4-6';
// Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges.Add();
// Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges[0].RangeStart := '2012-4-1';
// Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges[0].RangeEnd := '2012-4-6';
// Crpe1.ParamByName('PARAM_DATE', EmptyStr).CurrentValues.Add('2012-4-1');
//PARAM_DATE is a DATE Range
Crpe1.ParamByName('PARAM_DATE', EmptyStr).CurrentValues.Add('2012-4-1');
Crpe1.ParamByName('PARAM_DATE', EmptyStr).CurrentValues.Add('2012-4-6');
if Crpe1.Connect.Test then
Crpe1.Show
else
ShowMessage('Error Connecting');
Crpe1.DiscardSavedData;
finally
SetCurrentDir( ExtractFileDir(ParamStr(0)) );
end;
end;
你试过这样的事情吗?
i:= Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges.Add();
Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges.Items[i].RangeStart := '2012-4-1';
Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges.Itens[i].RangeEnd := '2012-4-6';
Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges.Add();
Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges[0].RangeStart := '2012,4,1';
Crpe1.ParamByName('PARAM_DATE', EmptyStr).Ranges[0].RangeEnd := '2012,4,6';
更新:VCL(文件:UCrpeUtl)中有一个名为CrDateToStr的函数,它采用TDateTime并返回这种格式的日期字符串。