XML文件的读取属性

本文关键字:属性 读取 文件 XML | 更新日期: 2023-09-27 17:50:22

我有这个XML文件,我可以读取所有节点

<?xml version="1.0" encoding="UTF-8"?>
<cteProc xmlns="http://www.portalfiscal.inf.br/cte" versao="1.04">
    <CTe xmlns="http://www.portalfiscal.inf.br/cte">
        <infCte versao="1.04" ID="CTe3512110414557000014604"></infCte>
    </CTe>
</cteProc> 

我试过用c#

阅读这个
string chavecte;        
string CaminhoDoArquivo = @"C:'Separados'13512004-procCTe.xml";
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(CaminhoDoArquivo); //Carregando o arquivo
chavecte = xmlDoc.SelectSingleNode("infCTe")
                    .Attributes.GetNamedItem("Id").ToString();

XML文件的读取属性

如果您想使用Linq to Xml

var xDoc = XDocument.Load(CaminhoDoArquivo);
XNamespace ns = "http://www.portalfiscal.inf.br/cte";
var chavecte = xDoc.Descendants(ns+"infCte").First().Attribute("id").Value;

PS:我假设你的xml的无效行是

<infCte versao="1.04" id="CTe3512110414557000014604"></infCte>

replace

chavecte = xmlDoc.SelectSingleNode("infCTe").Attributes.GetNamedItem("Id").Value;

XmlNamespaceManager nsmgr = new XmlNamespaceManager(xmlDoc.NameTable);
nsmgr.AddNamespace("ab", "http://www.portalfiscal.inf.br/cte");
chavecte = xmlDoc.SelectSingleNode("//ab:infCte", nsmgr)
                 .Attributes.GetNamedItem("Id").Value;

我也注意到,infCte没有ID属性正确定义在您的xml

另一个可能的解决方案是:

string CaminhoDoArquivo = @"C:'Separados'13512004-procCTe.xml";
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(CaminhoDoArquivo); //Carregando o arquivo
// Select the node you're interested in
XmlNode node = xmlDoc.SelectSingleNode("/cteProc/CTe/infCte");
// Read the value of the attribute "ID" of that node
string chavecte = node.Attributes["ID"].Value;