Pracuję z interfejsem API Exchange Web Services Managed API z danymi kontaktowymi. Mam następujący kod, który jest funkcjonalny , ale nie idealny:
foreach (Contact c in contactList)
{
string openItemUrl = "https://" + service.Url.Host + "/owa/" + c.WebClientReadFormQueryString;
row = table.NewRow();
row["FileAs"] = c.FileAs;
row["GivenName"] = c.GivenName;
row["Surname"] = c.Surname;
row["CompanyName"] = c.CompanyName;
row["Link"] = openItemUrl;
//home address
try { row["HomeStreet"] = c.PhysicalAddresses[PhysicalAddressKey.Home].Street.ToString(); }
catch (Exception e) { }
try { row["HomeCity"] = c.PhysicalAddresses[PhysicalAddressKey.Home].City.ToString(); }
catch (Exception e) { }
try { row["HomeState"] = c.PhysicalAddresses[PhysicalAddressKey.Home].State.ToString(); }
catch (Exception e) { }
try { row["HomeZip"] = c.PhysicalAddresses[PhysicalAddressKey.Home].PostalCode.ToString(); }
catch (Exception e) { }
try { row["HomeCountry"] = c.PhysicalAddresses[PhysicalAddressKey.Home].CountryOrRegion.ToString(); }
catch (Exception e) { }
//and so on for all kinds of other contact-related fields...
}
Jak powiedziałem, ten kod działa . Teraz chcę , jeśli to możliwe, trochę mniej ssać .
Nie mogę znaleźć żadnych metod, które pozwolą mi sprawdzić istnienie klucza w słowniku przed próbą uzyskania do niego dostępu, a jeśli spróbuję go odczytać (za pomocą .ToString()
) i nie istnieje, zgłoszony zostanie wyjątek:
500
Dany klucz nie był obecny w słowniku.
Jak mogę zmienić kod tego kodu, aby mniej ssał (nadal działając)?
TryGetValue
Podejście wydaje się, może to być najlepszym, ponieważ znalazłem tę stronę: goo.gl/7YN6 ... ale nie jestem pewien, jak go używać. W moim powyższym kodzierow
znajduje się obiekt „DataRow”, więc nie jestem pewien, czy twój przykładowy kod ma rację, ale ...