C# 使用XmlTextReader从元素读取属性
在下面的代码中,我将查找Undly元素,然后为类设置适当的属性。这是正确的方法吗?或者我应该创建一个新的XElement类,然后查找属性 我仍在学习XMLTextReader,并希望使用最佳实践 另外,我不确定是应该使用接受XML文件的字符串文件路径的构造函数,还是使用使用filestream的构造函数。使用filestream似乎有更快的性能 这是密码C# 使用XmlTextReader从元素读取属性,c#,filestream,xmltextreader,C#,Filestream,Xmltextreader,在下面的代码中,我将查找Undly元素,然后为类设置适当的属性。这是正确的方法吗?或者我应该创建一个新的XElement类,然后查找属性 我仍在学习XMLTextReader,并希望使用最佳实践 另外,我不确定是应该使用接受XML文件的字符串文件路径的构造函数,还是使用使用filestream的构造函数。使用filestream似乎有更快的性能 这是密码 using (var fs = new FileStream(RBMRBHTheoretical, FileMode.Open, FileAc
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&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&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似乎有更快的性能,如果没有实际的指标,就不可能有助于消除性能上的差异。是的,它是有效的。我将尝试获取指标。