从多个XML文件中读取两个节点的最有效方法?

时间:2013-10-07 15:11:43

标签: c# xml

我正在寻找一种从多个xml文件中检索2个字符串的快速有效方法。

他们自己的文件不是那么大只有50kb到100kb,文件的数量可以从无到100.我已经包含了一个非常小的xml文件样本我将会是使用。所有xml文件都是相同的格式,我只需要知道所有文件中的两件事,即:

    <Company>test bv.</Company>
    <Ship>sss testing</Ship>

我想将这些字符串存储在struct / class中,因为我不能在.net 3.5中使用Tuple(或者我错了吗?)

所以问题:最有效的方法是什么?使用Xdocument?使用xmlReader?或其他什么?

<?xml version="1.0" encoding="utf-8"?>
<Collection xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <Customer>
    <ID>-1</ID>
    <Updated>true</Updated>
    <Company>test bv.</Company>
    <Ship>sss testing</Ship>
    <Adress>fggfgggff gvg</Adress>
    <City>fgcgg</City>
    <ZipCode>5454fc</ZipCode>
    <Country>fcgggff</Country>
    <BTW_Nmbr>55</BTW_Nmbr>
    <IsTempCustomer>true</IsTempCustomer>
    <PhoneNumbers>
      <ContactData>
        <ID>21</ID>
        <Updated>true</Updated>
        <Description>455656567</Description>
        <Name>ghbbvh</Name>
        <IsSendable>false</IsSendable>
      </ContactData>
      <ContactData>
        <ID>22</ID>
        <Updated>true</Updated>
        <Description>2315098234146124302134</Description>
        <Name>asdfawegaebf</Name>
        <IsSendable>false</IsSendable>
      </ContactData>
    </PhoneNumbers>
    <EmailAdresses />
  </Customer>
  <Order>
    <ID>-1</ID>
    <Updated>true</Updated>
    <OrderNr>10330200</OrderNr>
    <OrderDate>1-1-2005</OrderDate>
    <StartDate>10-9-2013</StartDate>
    <ExpirationDate>20-10-2013</ExpirationDate>
    <Executor>Andre de Zwart</Executor>
    <Executors />
    <Reference />
    <OrderDetail />
    <IsDigital>true</IsDigital>
  </Order>
  <Materials>
    <MaterialData>
      <ID>108</ID>
      <Updated>true</Updated>
      <Description>ffdffggfg</Description>
      <Amount>34</Amount>
    </MaterialData>
    <MaterialData>
      <ID>109</ID>
      <Updated>true</Updated>
      <Description>ffccff</Description>
      <Amount>45</Amount>
    </MaterialData>
  </Materials>
  <HourExpenses>
    <HourExpensesData>
      <ID>43850</ID>
      <Updated>true</Updated>
      <Date>2013-10-06T00:00:00</Date>
      <Notes>lala</Notes>
      <Day>Sunday</Day>
      <Hours>0.01</Hours>
      <BusinessHours>0.01</BusinessHours>
      <TravledHoursTo>0</TravledHoursTo>
      <TravledHoursFrom>0</TravledHoursFrom>
      <Start>2013-10-06T12:27:00</Start>
      <Stop>2013-10-06T12:27:00</Stop>
    </HourExpensesData>
    <HourExpensesData>
      <ID>43849</ID>
      <Updated>true</Updated>
      <Date>2013-09-17T00:00:00</Date>
      <Notes>oke dus ik ben nu lekker aan het werk en ik typ wat spul er bij</Notes>
      <Day>Tuesday</Day>
      <Hours>0</Hours>
      <BusinessHours>0.01</BusinessHours>
      <TravledHoursTo>0</TravledHoursTo>
      <TravledHoursFrom>0</TravledHoursFrom>
      <Start>2013-09-17T12:31:31</Start>
      <Stop>2013-09-17T12:31:32</Stop>
    </HourExpensesData>
    <HourExpensesData>
      <ID>43855</ID>
      <Updated>true</Updated>
      <Date>2013-10-03T00:00:00</Date>
      <Notes>test</Notes>
      <Day>Thursday</Day>
      <Hours>0</Hours>
      <BusinessHours>0</BusinessHours>
      <TravledHoursTo>12</TravledHoursTo>
      <TravledHoursFrom>12</TravledHoursFrom>
      <Start>0001-01-01T00:00:00</Start>
      <Stop>0001-01-01T00:00:00</Stop>
    </HourExpensesData>
  </HourExpenses>
  <TravelExpenses>
    <TravelExpensesData>
      <ID>672</ID>
      <Updated>true</Updated>
      <Date>2013-09-27T00:00:00</Date>
      <Notes />
      <KmTo>45</KmTo>
      <KmFrom>45</KmFrom>
      <Declaration>0</Declaration>
    </TravelExpensesData>
  </TravelExpenses>
  <Signatures>
    <ID>-1</ID>
    <Updated>true</Updated>
    <OrderID>10330200</OrderID>
    <Completed>false</Completed>
    <Notes>yay het werkt ;D</Notes>
  </Signatures>
  <RemovedDataList />
</Collection>

1 个答案:

答案 0 :(得分:3)

我会以最简单的方式使用LINQ to XML:

var query = from file in files
            let doc = XDocument.Load(file)
            from customer in doc.Descendants("Customer")
            select new {
               Company = (string) customer.Element("Company"),
               Ship = (string) customer.Element("Ship")
            };

我希望它已经很快了 - 但你应该弄清楚你的确切性能要求,然后测试它们。 (你几乎肯定不需要&#34;最有效的方式 - 你需要一个足够有效的方式,同时保持代码的可读性。)

请注意,如果您希望将值传播到当前方法之外,则应创建自己的类来表示公司/船舶对。