我有以下两个功能:
private object[] GetFormatedDataArray(
Dienstleistungsreservierung dlres,
KostenstellenProvider kstProvider)
{
SAPKonto konto;
try { konto = KontierungsProvider.Instance.GetSAPKonto(dlres); }
catch { konto = new SAPKonto(); konto.KontoText = "UNBEKANNT"; }
Kostenstelle kst = kstProvider.GetKostenstelle(dlres.Raumreservierung.Buchung);
KostenstellenValidator.Validate(kst);
return new object[] {
dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.KonfStandort,
dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner.AnsprechPartnerName,
......
}
有可能值:
dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner
为null,因为我已经创建了一个if子句来创建.csv文件,如果值为null或者应该创建文件,那么他应该创建文件。
使用该函数/返回该函数的值,我创建一个.csv文件。
{
.....
var file = GetCsvFile(dl, accDate);
// CSV werden auf Platte geschrieben!
var csvWriter = new CSVWriter(file);
csvWriter.WriteLine(GetHeader());
foreach (Dienstleistungsreservierung dlres in dlDic[dl])
{
if (dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner == null || dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner != null)
{
csvWriter.WriteLine(GetFormatedDataArray(dlres, kstProvider));
}
}
csvWriter.Flush();
....
}
但错误仍然存在?还有其他方法可以解决吗?
答案 0 :(得分:2)
if (dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner == null ||
dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner != null)
您的if
声明包含矛盾检查。如果dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner
的值可能为null,那么您应该检查它是否为null然后继续。像下面这样的东西
if (dlres.Raumreservierung.VirtualRaum.Etage.Gebaeude.Partner != null)