Exemplo de XML:
<AssignmentHistory>
<PublicTalkInfo>
<PublicTalkNumber>21</PublicTalkNumber>
<PublicTalkSpeaker>Name3</PublicTalkSpeaker>
<PublicTalkCongregation>Place3</PublicTalkCongregation>
</PublicTalkInfo>
<PublicTalkInfo>
<MeetingDate>2023-10-15</MeetingDate>
<PublicTalkNumber>21</PublicTalkNumber>
<PublicTalkSpeaker>Name</PublicTalkSpeaker>
<PublicTalkCongregation>Place</PublicTalkCongregation>
</PublicTalkInfo>
<PublicTalkInfo>
<MeetingDate>2023-11-15</MeetingDate>
<PublicTalkNumber>21</PublicTalkNumber>
<PublicTalkSpeaker>Name2 </PublicTalkSpeaker>
<PublicTalkCongregation>Place</PublicTalkCongregation>
</PublicTalkInfo>
</AssignmentHistory>
Eu cortei para simplificar.
public string[] GetHistoryForTalkOutline(string historyDatabase, int talknumber)
{
List<string> list = new List<string>();
try
{
XDocument doc = XDocument.Load(historyDatabase);
var ptInfo = doc
.Descendants("PublicTalkInfo")
.Where(p => p.Element("PublicTalkNumber").Value == talknumber.ToString()).ToList();
SimpleLog.Log(ptInfo.Count().ToString());
foreach (var pt in ptInfo)
{
var date = pt.Element("MeetingDate");
var speaker = pt.Element("PublicTalkSpeaker");
var cong = pt.Element("PublicTalkCongregation");
if (date != null && speaker != null && cong != null)
{
DateTime objectdate = DateTime.Parse(date.Value);
string histitem = objectdate.ToString("d") + ", ";
histitem += speaker.Value + " (";
histitem += cong.Value + ")";
list.Add(histitem);
}
}
return list.ToArray();
}
catch (Exception ex)
{
SimpleLog.Log(ex);
return null;
}
}
Tenho certeza de que o código pode ser simplificado. Mas como posso construir minha lista final de strings com o conteúdo em ordem decrescente de data? Observe que algumas entradas não possuem os campos.
Em vez de armazenar todos os valores em uma lista de strings, você pode mantê-los em um formato que retenha o valor da data. Por exemplo, usando uma tupla :
Mais tarde, quando você adicionar itens à lista, faça o seguinte:
E para retornar os valores na ordem que você precisa, use um Linq simples:
Talvez tente algo nesse sentido
Se quiser que elementos sem data de reunião apareçam no topo da lista, você pode substituir
DateTime.MinValue
->DateTime.MaxValue
Talvez algo assim deva ajudar::