C # преобразовать XML в строку для поиска

#c# #xml #string

#c# #xml #строка

Вопрос:

Я пытаюсь выполнить поиск в XML-документе для получения конкретной информации. В первой части программы я отображаю всю информацию из XML на консоль (это легко, и я это сделал), а во второй я пытаюсь выполнить поиск среди узлов для конкретной информации, чтобы отобразить ее на консоли. Я тоже это делал, но я не знаю, как читать XML из XML-файла (order.xml ) и преобразуйте его в строку, чтобы использовать его.

Это мой код:

order.xml

 <?xml version="1.0" encoding="utf-8" ?>
<ordercat>
  <order order_ID="1" employee_ID="125">
    <CustomerId>1</CustomerId>
    <OrderDate>19.12.2009</OrderDate>
    <ShippedDate>21.12.2011</ShippedDate>
    <ShipName>Sven Skanske</ShipName>
    <ShipAddress>Stockholm 542, Stockolm</ShipAddress>
    <ShipCountry>Sweden</ShipCountry>
  </order>
  <order order_ID="2" employee_ID="145">
    <CustomerId>5</CustomerId>
    <OrderDate>25.10.2010</OrderDate>
<ShippedDate>31.10.2010</ShippedDate>
<ShipName>Jan Hoznovski</ShipName>
<ShipAddress>Warsawska 212, Warsaw</ShipAddress>
<ShipCountry>Poland</ShipCountry>
  </order>
  <order order_ID="3" customerID="4" employee_ID="112">
    <CustomerId>4</CustomerId>
    <OrderDate>15.10.2011</OrderDate>
    <ShippedDate>16.10.2011</ShippedDate>
    <ShipName>Martin Petrzilka</ShipName>
    <ShipAddress>U Hrocha 2145, Sedlcany</ShipAddress>
    <ShipCountry>Czech Republic</ShipCountry>
  </order>
</ordercat>
 

И это код C #:

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Xml;
using System.Xml.XPath;

namespace XML
{
    class Program
    {
        static void Main(string[] args)
        {
            DataSet ds = new DataSet();
            string pathe = @"D:DocsKristianstadHomework_5XMLXMLorder.xml";
            ds.ReadXml(pathe);

        foreach (DataTable dt in ds.Tables)
        {
            foreach (DataRow row in dt.Rows)
            {
                foreach (DataColumn column in dt.Columns)
                {
                    Console.WriteLine(row[column]);
                }
                Console.WriteLine();
            }
        }
        Console.WriteLine("Press any key to continue ...");
        Console.ReadKey();
        Console.WriteLine("");

        string xmlText = "<?xml version="1.0" encoding="utf-8" ?>";
        xmlText  = "<ordercat>";
        xmlText  = "<order order_ID="1" employee_ID="125">";
        xmlText  = "<CustomerId>1</CustomerId>";
        xmlText  = "<OrderDate>19.12.2009</OrderDate>";
        xmlText  = "<ShippedDate>21.12.2011</ShippedDate>";
        xmlText  = "<ShipName>Sven Skanske</ShipName>";
        xmlText  = "<ShipAddress>Stockholm 542, Stockolm</ShipAddress>";
        xmlText  = "<ShipCountry>Sweden</ShipCountry>";
        xmlText  = "</order>";
        xmlText  = "<order order_ID="2" employee_ID="145">";
        xmlText  = "<CustomerId>5</CustomerId>";
        xmlText  = "<OrderDate>25.10.2010</OrderDate>";
        xmlText  = "<ShippedDate>31.10.2010</ShippedDate>";
        xmlText  = "<ShipName>Jan Hoznovski</ShipName>";
        xmlText  = "<ShipAddress>Warsawska 212, Warsaw</ShipAddress>";
        xmlText  = "<ShipCountry>Poland</ShipCountry>";
        xmlText  = "</order>";
        xmlText  = "<order order_ID="3" customerID="4" employee_ID="112">";
        xmlText  = "<CustomerId>4</CustomerId>";
        xmlText  = "<OrderDate>15.10.2011</OrderDate>";
        xmlText  = "<ShippedDate>16.10.2011</ShippedDate>";
        xmlText  = "<ShipName>Martin Petrzilka</ShipName>";
        xmlText  = "<ShipAddress>U Hrocha 2145, Sedlcany</ShipAddress>";
        xmlText  = "<ShipCountry>Czech Republic</ShipCountry>";
        xmlText  = "</order>";
        xmlText  = "</ordercat>";

        XmlDocument xml = new XmlDocument();
        xml.LoadXml(xmlText);

        XmlNodeList xnList = xml.SelectNodes("/ordercat/order[CustomerId='5']");
        foreach (XmlNode xn in xnList)
        {
            string shippedDate = xn["ShippedDate"].InnerText;
            string shipName = xn["ShipName"].InnerText;
            Console.WriteLine(shippedDate   " "   shipName);
        }
    }

}
}
 

Как вы можете видеть, первая часть получает информацию из XML-файла, но во второй части я должен использовать строку с XML-информацией. Итак, чтобы повторить вопрос. Как использовать XML-файл во второй части примера, а не строку? Или как я могу преобразовать XML-файл в строку, а затем использовать его во второй части?

Ответ №1:

Непонятно, почему вы загружаете XML-документ в a DataSet для начала. Просто используйте XmlDocument (или предпочтительнее XDocument , если вы используете .NET 3.5 или более позднюю версию) во всем своем коде. Я бы также настоятельно рекомендовал вообще не создавать XML в виде строки в вашем коде. В принципе, когда вы хотите иметь дело с XML, используйте XML API.

Итак, чтобы загрузить XML-файл:

 // XmlDocument version
XmlDocument doc = new XmlDocument();
doc.Load(filename);

// XDocument version
XDocument doc = XDocument.Load(filename);
 

Ответ №2:

Как насчет

  string xmlString =  System.IO.File.ReadAllText(fileName);