C# 使用XmlTextReader从元素读取属性

C# 使用XmlTextReader从元素读取属性,c#,filestream,xmltextreader,C#,Filestream,Xmltextreader,在下面的代码中,我将查找Undly元素,然后为类设置适当的属性。这是正确的方法吗?或者我应该创建一个新的XElement类,然后查找属性 我仍在学习XMLTextReader,并希望使用最佳实践 另外,我不确定是应该使用接受XML文件的字符串文件路径的构造函数,还是使用使用filestream的构造函数。使用filestream似乎有更快的性能 这是密码 using (var fs = new FileStream(RBMRBHTheoretical, FileMode.Open, FileAc

在下面的代码中,我将查找Undly元素,然后为类设置适当的属性。这是正确的方法吗?或者我应该创建一个新的XElement类,然后查找属性

我仍在学习XMLTextReader,并希望使用最佳实践

另外,我不确定是应该使用接受XML文件的字符串文件路径的构造函数,还是使用使用filestream的构造函数。使用filestream似乎有更快的性能

这是密码

using (var fs = new FileStream(RBMRBHTheoretical, FileMode.Open, FileAccess.Read))
{
    using (var xmlReader = new XmlTextReader(fs))
    {
        while (xmlReader.Read())
        {
            if (xmlReader.NodeType == XmlNodeType.Element)
            {
                if (string.Equals(xmlReader.Name, "Undly"))
                {
                    occPLList.Add(new OccPL
                    {
                        Symbol = (string)xmlReader.GetAttribute("Sym").ToString().Trim(),
                        Description = (string)xmlReader.GetAttribute("Desc").ToString().Trim(),
                        Price = xmlReader.GetAttribute("Px") == null ? 0 : Convert.ToDecimal(xmlReader.GetAttribute("Px").ToString().Trim()),
                        Currency = (string)xmlReader.GetAttribute("Ccy").ToString().Trim()
                    });
                }
            }
        }
    } 
}

public class OccPL
{
    public string Description { get; set; }
    public decimal Price { get; set; }
    public string Currency { get; set; }
    public string Symbol { get; set; }
}
以下是xml文件:

<FIXML r="20030618" s="20040109" v="4.4" xr="FIA" xv="1" xmlns="http://www.fixprotocol.org/FIXML-4-4" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation ="http://www.fixprotocol.org/FIXML-4-4 https://optionsclearing.com/components/docs/membership/dds_ref/fia_1_1/fixml-main-4-4-FIA-1-1.xsd">
 <Batch>
   <SecList ListTyp="109" ListID="20175" BizDt="2017-12-07">
     <SecL Ccy="USD">
       <Instrmt Desc="iShares S&amp;P 100 ETF" SecTyp="OPT" SubTyp="ETO" Sym="OEF" Mult="100.0">
         <AID AltID="00013" AltIDSrc="RBHP"/>
       </Instrmt>
       <InstrmtExt>
        <Attrb Typ="101" Val="1.0000"/>
        <Attrb Typ="108" Val="1.0000"/>
       </InstrmtExt>
       <Undly Desc="iShares S&amp;P 100 ETF" Px="117.110000" Ccy="USD" Sym="OEF" ID="464287101" Src="1"/>
       <Stip Typ="RBHMIN" Val="2.500"/>
       <Stip Typ="CPMMIN" Val="3.750"/>
     </SecL>
    </SecList>
  </Batch>
 </FIXML>

因为在FIXML元素中有一个用于该XML的XSD,所以我可能会使用XSD.exe工具从该XSD生成一个类,并反序列化到生成的类的实例,然后为您自己的对象选择所需的位


走反序列化路线是有性能的,但很严格。如果XML与模式不匹配,它将中断。XmlTextReader和LINQtoXML通常速度稍慢,但处理起来更灵活。如果您计划处理大量任意XML,那么您所做的一切都很好。如果您的XML将有一个定义良好的模式,那么当您可以使用XSD自动生成所需的所有内容并使用反序列化程序时,不要浪费时间编写一堆自定义反序列化代码。

这样做正确吗?它有用吗?使用filestream似乎有更快的性能,如果没有实际的指标,就不可能有助于消除性能上的差异。是的,它是有效的。我将尝试获取指标。