首页 > 解决方案 > 如何在这个 xml 文件中设置日期/日期时间格式?

问题描述

我在 LINQ 语句中使用下面的 xml 文件,其中我将“Startdate”和“EndDate”与 DateTime 值匹配。并因为“字符串”和“日期时间”比较而出错。我应该在这里做什么来修改xml?

<?xml version="1.0" encoding="utf-8" ?>
<IndiaLoanProduct xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<Program>
<ProgramID>6</ProgramID>
<Name>Primary Loan</Name>
<InterestRate>0.23</InterestRate>
<StartDate>2018-12-20</StartDate>
<EndDate>2019-03-31</EndDate>
</Program>

<Program>
<ProgramID>6</ProgramID>
<Name>Primary Loan</Name>
<InterestRate>0.25</InterestRate>
<StartDate>2019-04-1</StartDate>
<EndDate>2099-12-31</EndDate>
</Program>
</IndiaLoanProduct>

出现错误的代码:-

XDocument doc = XDocument.Load(Server.MapPath("/Resources/India_LoanProduct.xml"));

var ns = doc.Root.GetDefaultNamespace();

var result = (from program1 in doc.Descendants(ns + "Program")
              where Convert.ToInt32(program1.Element(ns + "ProgramID").Value) == programName.Id 
                 && (Comparedate < (DateTime)(program1.Element(ns + "EndDate")).Value) 
              select program1).FirstOrDefault();

标签: c#asp.netxmllinq

解决方案


基于OP的代码更新

您需要使用 DateTime.Parse 解析元素值。

var result = (from program1 in doc.Descendants(ns + "Program")
              where Convert.ToInt32(program1.Element(ns + "ProgramID").Value) == programName.Id 
                  && (Comparedate < (DateTime.Parse(program1.Element(ns + "EndDate").Value))) 
                  select program1).FirstOrDefault();

推荐阅读