有人能帮助我如何使用Linq-to-XML阅读下面的XML文档吗?
<?xml version= 1.0 encoding= UTF-8 ?>
<cXML>
<Request>
<OrderRequest>
<OrderRequestHeader orderID="xy1234" orderDate="2007-01-1T15:5400+10:00" type="new" orderVersion="001">
<Total>
<Money currency="NZ">34.06</Money>
</Total>
<ShipTo>
<Address>
<Name xml:lang="en">xyz</Name>
<PostalAddress name="xyz">
<Street>xyz street</Street>
<City>xyz</City>
</PostalAddress>
</Address>
</ShipTo>
<BillTo>
<Address>
<Name xml:lang="en">XYZ</Name>
<PostalAddress name="XYZ">
<Street>PO BOX 1234</Street>
<City>xyz</City>
<State>xyz state</State>
</PostalAddress>
</Address>
</BillTo>
<Contact role="xxx" addressID="123456789">
<Name xml:lang="en">XYZ</Name>
<Email name="business">XYZ@ms.com.nz</Email>
<Phone>
<TelephoneNumber>
<Number>1234-1234</Number>
</TelephoneNumber>
</Phone>
</Contact>
<Contact role="ShipTo">
<Name xml:lang="en">XYZ</Name>
</Contact>
<Contact role="Supplier">
<Name xml:lang="en">XYZ pty ltd</Name>
</Contact>
</OrderRequestHeader>
<ItemOut quantity="20" lineNumber="1" requestedDeliveryDate="2007-01-01T00:0000+10:00">
<ItemID>
<SupplierPartID>12345678</SupplierPartID>
</ItemID>
<ItemDetail>
<UnitPrice>
<Money currency="NZ">32</Money>
</UnitPrice>
<Description xml:lang="en">abc description</Description>
<UnitOfMeasure>CU</UnitOfMeasure>
<Classification domain="N/A"/>
<ManufacturerPartID>12345678</ManufacturerPartID>
<Extrinsic name="StockCode">12345</Extrinsic>
<Extrinsic name="Quantity">1</Extrinsic>
</ItemDetail>
</ItemOut>
<ItemOut quantity="10" lineNumber="2" requestedDeliveryDate="2007-01-01T00:0000+10:00">
<ItemID>
<SupplierPartID>12345678</SupplierPartID>
</ItemID>
<ItemDetail>
<UnitPrice>
<Money currency="NZ">32</Money>
</UnitPrice>
<Description xml:lang="en">abc description</Description>
<UnitOfMeasure>CU</UnitOfMeasure>
<Classification domain="N/A"/>
<ManufacturerPartID>12345678</ManufacturerPartID>
<Extrinsic name="StockCode">23333</Extrinsic>
<Extrinsic name="Quantity">1</Extrinsic>
</ItemDetail>
</ItemOut>
</OrderRequest>
我尝试过使用此代码,但它给出了null或对象引用未设置错误:
XDocument xdoc = XDocument.Load(@"C:PO.xml");
var itemOut = (from c in xdoc.Descendants("OrderRequest")
select new
{
SupplierID = c.Element("Money").Value ,
Currency = c.Attribute("currency").Value,
Money = c.Element("Money").Value,
Description = c.Element("Description").Value,
ManufacturerPartID = c.Element("ManufacturerPartID").Value,
Extrinsic = c.Attribute("name").Value
});
foreach (var element in itemOut)
{
Console.WriteLine(element.SupplierID);
}
Console.ReadLine();