Данные на корневом уровне недействительны. Линия 1, позиция 1 MonoTouch - PullRequest
2 голосов
/ 25 марта 2012

Я пытаюсь разобрать какой-то XML, однако я получаю сообщение об ошибке выше этого предложения.

Вот мой код:

     class Program
{


    static void Main(string[] args)
    {

        string xml = @"<?xml version=""1.0"" encoding=""UTF-8""?><rss version=""2.0"" xmlns:georss=""http://www.georss.org/georss"">
<channel>
    <title>asp.net Jobs in Boston, MA | Indeed.com</title>


    <link>http://www.indeed.com/q-asp.net-l-boston,-jobs.html</link>
    <description>Indeed.com - one search. all jobs. Search thousands of sites for asp.net Jobs in Boston, MA</description>
    <language>en</language>
    <copyright>Copyright (c) 2012 Indeed, Inc All rights reserved.</copyright>
    <lastBuildDate>Sun, 25 Mar 2012 19:43:15 GMT</lastBuildDate>
    <image>
        <url>http://www.indeed.com/images/indeed_rss.png</url>
        <title>Indeed.com - one search. all jobs.</title>
        <link>http://www.indeed.com/</link>
    </image>
    <item>
        <title>Software Engineer with ASP.Net applications experience - The Integrity Group -  Andover, MA</title>

        <link>http://www.indeed.com/job/Software-Engineer-With-ASP-Net-Application-Experience-at-The-Integrity-Group-in-Andover,-MA-6ab16ba39cc13536</link>
        <source>JobHost</source>
        <guid isPermaLink=""false"">d61c3504e9df0fc13be4abb4be209c38</guid>
        <pubDate>Wed, 21 Mar 2012 05:04:47 GMT</pubDate>
        <description>layers and preferably service based architecture. ASP.Net web applications with server-side controls and... Solid experience in ASP.Net, SQL Server, C#, XML, XML... &lt;br/&gt;
        From JobHost - 21 Mar 2012 05:04:47 GMT
        -  View all &lt;a href=&#034;http://www.indeed.com/l-Andover,-MA-jobs.html&#034;&gt;Andover jobs&lt;/a&gt;
        </description>

        <georss:point>42.64835 -71.15934</georss:point>
    </item>
</channel></rss>";

        foreach (SavedJob sj in GetJobs(xml))
        {
            Console.WriteLine(sj.title);
        }

    }

    public static List<SavedJob> GetJobs(string xml)
    {
        //http://forum.unity3d.com/threads/31314-Include-Files-in-build

        XmlDocument xmlDoc = new XmlDocument();
        System.IO.StringReader stringReader = new System.IO.StringReader(xml);
        stringReader.Read();

        //http://unity3d.qatohost.com/questions/161528/loading-a-large-xml-file-200-multi-level-nodes-int.html

        // skip BOM 
        xmlDoc.LoadXml(stringReader.ReadToEnd());

        List<SavedJob> SavedJobs = new List<SavedJob>();
        try
        {
            foreach (XmlElement found in xmlDoc.GetElementsByTagName("item"))
            {

                SavedJob sj = new SavedJob();
                sj.title = found.GetElementsByTagName("title")[0].InnerText;
                sj.link = found.GetElementsByTagName("link")[0].InnerText;
                sj.description = found.GetElementsByTagName("description")[0].InnerText;
                DateTime dt = new DateTime();
                DateTime.TryParse(found.GetElementsByTagName("pubDate")[0].InnerText, out dt);
                sj.date = dt;
                SavedJobs.Add(sj);
            }
        }
        //data source is null
        catch (Exception)
        {

        }

        return SavedJobs;

    }

}

public class SavedJob
{
    public string title { get; set; }
    public string link { get; set; }
    public string description { get; set; }
    public DateTime date { get; set; }
}

Моя цель - создать панель загрузки в MonoTouch, однако я не могу загрузить строку, потому что XML плохой.Есть ли способ обойти это?

    LoadingView lv = new LoadingView ();

        WebClient wc = new WebClient ();
        wc.DownloadStringCompleted += delegate(object sender, DownloadStringCompletedEventArgs e) {
            // We got the async result now display data
            InvokeOnMainThread (delegate {
                if (e.Result != null) {
                    SavedJobs = basicOperations.GetJobs (e.Result);
                    TableView.Source = new DataSource (this);
                    TableView.ReloadData();
                    lv.Hide ();
                }
            });

        };

        lv.Show ("Loading");
        wc.DownloadStringAsync (new Uri (uString));

Ответы [ 2 ]

2 голосов
/ 26 марта 2012

Ваш код показывает:

    System.IO.StringReader stringReader = new System.IO.StringReader(xml);
    stringReader.Read();
    xmlDoc.LoadXml(stringReader.ReadToEnd());

Что это делает:

  • создать программу чтения строк в ""
  • затем прочитайте первый символ - "<" </li>
  • затем попробуйте загрузить оставшиеся символы в формате xml - т.е. "xml ...>"

Так что вам нужно избегать первоначального вызова stringReader.Read();, который убирает первую угловую скобку открытия из xml - делая его недействительным при 1,1

0 голосов
/ 26 марта 2012

Еще лучший способ сделать это - создать файл из DownloadFileAsync:

WebClient wc = new WebClient();
        string fPath = Environment.GetFolderPath(Environment.SpecialFolder.Personal) + "/myfile.xml";
        wc.DownloadFileCompleted += delegate(object sender, AsyncCompletedEventArgs e) {
            BasicOperations bas = new BasicOperations();

            //save results as file

            SavedJobs = bas.GetJobs(fPath);
            TableView.Source = new DataSource (this);
            TableView.ReloadData();
        };



        wc.DownloadFileAsync(new Uri(uString), fPath);
...