xml и условие по dateTime - PullRequest
       29

xml и условие по dateTime

1 голос
/ 20 марта 2011

XML

<CalendarFairs> 
    <CalendarFair>
        <DateStart>2011-04-05T00:00:00</DateStart>
       <DateEnd>2011-04-09T00:00:00</DateEnd>
        <Title>aaaa</Title>   
       <IdExecutive>1</IdExecutive>
   </CalendarFair>
  <CalendarFair>
      <DateStart>2011-04-16T00:00:00</DateStart>
      <DateEnd>2011-04-19T00:00:00</DateEnd>
      <Title>bbb</Title>
      <IdExecutive>2</IdExecutive>
  </CalendarFair>
<CalendarFairs>

Код

  var elements = from element in doc.Descendants("CalendarFair")
                           where DateTime.Parse (element.Elements ("DateStart").ToString())==DateTime.Now 
                           select new
                           {
                               dateStart = element.Element("DateStart").Value,
                               dateEnd=element.Element("DateEnd").Value,
                               title=element.Element("Title").Value,
                               idExcutive = element.Element("IdExecutive").Value ,
                           };

foreach (var item in elements)//send this error

            {}
System.FormatException: The string was not recognized as a valid DateTime. There is a 
unknown word starting at index 0.

почему ошибка?

Ответы [ 2 ]

1 голос
/ 20 марта 2011

Попробуйте изменить его следующим образом:

var elements = from element in doc.Descendants("CalendarFair")
               let start = element.Element("DateStart").Value
               where DateTime.Parse (start)==DateTime.Now.Date
               select new
               {
                   dateStart = start,
                   dateEnd=element.Element("DateEnd").Value,
                   title=element.Element("Title").Value,
                   idExcutive = element.Element("IdExecutive").Value ,
               };

РЕДАКТИРОВАТЬ: на основе XML, который вы разместили запрос выше, работает очень хорошо.Попробуйте проверить это с помощью этого ввода:

<CalendarFairs> 
    <CalendarFair>
        <DateStart>2011-04-05T00:00:00</DateStart>
       <DateEnd>2011-04-09T00:00:00</DateEnd>
        <Title>aaaa</Title>   
       <IdExecutive>1</IdExecutive>
   </CalendarFair>
  <CalendarFair>
      <DateStart>2011-03-20T00:00:00</DateStart>
      <DateEnd>2011-04-19T00:00:00</DateEnd>
      <Title>bbb</Title>
      <IdExecutive>2</IdExecutive>
  </CalendarFair>
</CalendarFairs>

Обратите внимание, что я вставил сегодняшнюю дату начала .На самом деле я думаю, что результат был пустым только потому, что не было записей с фактической датой.

0 голосов
/ 20 марта 2011

Звучит так, как будто одна или несколько введенных вами <DateStart> строк не в допустимом формате DateTime.

Можете ли вы опубликовать пример входного XML?

Возможно, вам нужно указать формат даты, используя ParseExact - http://msdn.microsoft.com/en-us/library/w2sa9yss.aspx

...