下面这段XML是一个更大的XML的一部分。我试了一次又一次地得到地址行1,2,3和城市和州,邮政编码和国家。我想把这个功能化,这样我就可以选择
这些地址基于invoiceheader id=“xxxx”,但是我总是碰到墙。
我尝试了下面的查询或其他类似的查询,但是我一直得到一个错误对象引用,它没有设置为对象的实例。
这是我的问题,有人能指出我明显的错误吗?

 IEnumerable<string> partNos =
            from item in PurchaseOrderXml.Descendants("RemitTo").Descendants("Address")
            where (string)item.Attribute("id").Value == "23951768"
            select (string)item;



<Invoice>
    <InvoiceHeader id="23951768" status="InProcess">
        <InvoiceName />
        <InvoiceNumber>23951768</InvoiceNumber>
        <InvoiceDate>2014-09-26 00:00:00.0</InvoiceDate>
        <DueDate>2014-10-26 00:00:00.0</DueDate>
        <SupplierInvoiceNo>534254504</SupplierInvoiceNo>
        <InvoiceType>Invoice</InvoiceType>
      <Supplier id="3825405">
        <ContactInfo type="main">
              <Address>
                <AddressLine lineNumber="1">Post </AddressLine>
                <AddressLine lineNumber="2">30 Street</AddressLine>
                <AddressLine lineNumber="3">30 Street</AddressLine>
                <City>Saint Louis</City>
                <State>MO</State>
                <PostalCode>63103-2530</PostalCode>
                <Country isoCountryCode="US">United States</Country>
            </Address>
        </ContactInfo>
    </Supplier>
        <BillTo>
        <Address>
            <AddressLine lineNumber="1">vvvv</AddressLine>
            <AddressLine lineNumber="2">vvvv</AddressLine>
            <City>Philadelphia</City>
            <State>PA</State>
            <PostalCode>19222</PostalCode>
            <Country isoCountryCode="US">United States</Country>
        </Address>
          </BillTo>
        <RemitTo>
            <Address>
                <AddressLine lineNumber="1">P O BOX 535182</AddressLine>
                <AddressLine lineNumber="2" />
                <AddressLine lineNumber="3" />
                <City>ATLANTA</City>
                <State>GA</State>
                <PostalCode>303535182</PostalCode>
                <Country isoCountryCode="US">United States</Country>
            </Address>
        </RemitTo>
     </InvoiceHeader>
</Invoice>

最佳答案

item range变量对应于没有id属性的address元素。相反,您需要一个查询,该查询首先查找(或筛选)适当的invoiceheader,然后查找匹配的invoiceheader的address元素desendents。
以下是查找InvoiceHeader的示例:

var Header = PurchaseOrderXml.Descendants("InvoiceHeader")
.FirstOrDefault(header => (string)header.Attribute("id").Value == headerId);

您可以检查是否找到标题(Header != null)。一旦有了头,就在给定元素的范围内做任何需要做的事情。例子:
var RemitToAddress = Header.Descendants("RemitTo").Descendants("Address").FirstOrDefault();

您可能希望检查头中的其他元素,因此将查询拆分成这样的部分可以保持您的意图清晰。
还要注意,我使用了Descendants,但是如果它与您的模式更好地匹配,您也可以使用Elements
另一个例子是,要获取AddressLine元素并将它们连接起来,您可以尝试以下方法:
IEnumerable<string> AddressLines = RemitToAddress.Elements("AddressLine")
.OrderBy(line => (int)line.Attribute("lineNumber"))
.Select(line => line.Value);

var AddressText = string.Join("\n", AddressLines);

10-02 15:02