0

「ウェブストア」asp.net mvc 3アプリをほとんど作成しましたが、1つのウェブストアからいくつかのアイテムをデータベースに入力したいと考えています。これらは、パートナーのアイテムに関する情報を xml ファイルで提供します。1 つダウンロードしましたが、150 MB あるので、ただ開いて内容を確認することはできません。

ファイル内の情報も私のモデルと完全には一致しないため、何らかの形で「マージ」する必要があります。どうすればできますか?xml をダウンロードして逆シリアル化する方法についてのすばらしいチュートリアルをご存知でしょうか?

4

2 に答える 2

2

LINQ to XML は素晴らしいプロバイダーです。XElements の形式で XML ドキュメントをクエリできます。

using System.Xml.Linq;

xml が提供する uri を介してコードで xml をダウンロードできる場合は、System.IO.File を介してメモリにロードし、LINQ to XML で操作できます。

string xml = new WebClient().DownloadString(url);

XDocument doc = XDocument.Parse(xml);

//item being the name of the node
var itemDescendent = doc.Descendants("item"); 

var query = from item in itemDescendent
            select new
            {
               itemId = item.Attribute("id"),
               itemName = item.Attribute("Name")
            };

foreach (item in query)
{
   //dostuff
}

これにより、ノードから属性が選択されます。ノード内のノードを取得するには、少し異なる方法が必要になります。

于 2013-01-25T17:29:09.993 に答える
0

これまたはこれを使用してください

 using System;
    using System.IO;
    using System.Xml.Serialization;

namespace xmlTest
{
    class Program
    {
        static void Main(string[] args)
        {
            var articles = new Articles();
            articles.ArticleArray = new ArticlesArticle[2]
            {
                new ArticlesArticle()
                    {
                        Guid = Guid.NewGuid(),
                        Order = 1,
                        Type = "deal_abstract",
                        Title = "Abu Dhabi...",
                        Summary = "Abu Dhabi...",
                        ArticleDate = new DateTime(2011,2,24)
                    },
                new ArticlesArticle()
                    {
                        Guid = Guid.NewGuid(),
                        Order = 2,
                        Type = "deal_abstract",
                        Title = "Abu Dhabi...",
                        Summary = "China...",
                        ArticleDate = new DateTime(2011,2,23)
                    },
            };

            var sw = new StringWriter();
            var xmlSer = new XmlSerializer(typeof (Articles));
            var noNamespaces = new XmlSerializerNamespaces();
            noNamespaces.Add("", ""); 
            xmlSer.Serialize(sw, articles,noNamespaces);
            Console.WriteLine(sw.ToString());
        }
    }

    [XmlRoot(ElementName = "articles", Namespace = "", IsNullable = false)]
    public class Articles
    {
        [XmlElement("article")]
        public ArticlesArticle[] ArticleArray { get; set; }
    }

    public class ArticlesArticle
    {
        [XmlElement("guid")]
        public Guid Guid { get; set; }
        [XmlElement("order")]
        public int Order { get; set; }
        [XmlElement("type")]
        public string Type { get; set; }
        [XmlElement("textType")]
        public string TextType { get; set; }
        [XmlElement("id")]
        public int Id { get; set; }
        [XmlElement("title")]
        public string Title { get; set; }
        [XmlElement("summary")]
        public string Summary { get; set; }
        [XmlElement("readmore")]
        public string Readmore { get; set; }
        [XmlElement("fileName")]
        public string FileName { get; set; }
        [XmlElement("articleDate")]
        public DateTime ArticleDate { get; set; }
        [XmlElement("articleDateType")]
        public string ArticleDateType { get; set; }
    }
}
于 2013-01-25T18:10:09.990 に答える