使用HTML Agility Pack进行错误编码

character-encoding encoding html-agility-pack unicode

我试图解析http://www.wein-wg.de/wwg/rheinhessen/worms-pfeddersheim/weingut-goldschmidt/但是无法得到正确的字符集。该网站正在使用iso-8859-1。不知何故,所有unicode字符都显示为?在Visual Studio中。

是否有可能在Visual Studio或其他任何地方将其转移到正确的字符集?

一般承认的答案

using HtmlAgilityPack;

HtmlDocument doc;
HtmlWeb web = new HtmlWeb();

private void getPage(string url)
{
    web.OverrideEncoding = Encoding.GetEncoding("iso-8859-1");
    doc = web.Load(url);
    webBrowser1.DocumentText = doc.DocumentNode.OuterHtml;
}

getPage("http://www.wein-wg.de/wwg/rheinhessen/worms-pfeddersheim/weingut-goldschmidt/");

热门答案

解决了:

        HtmlWeb Webget = new HtmlWeb();
        HtmlDocument doc = new HtmlDocument();
        Webget.AutoDetectEncoding = false;
        Webget.OverrideEncoding = Encoding.UTF8;

        doc_tmp.OptionOutputAsXml = true;
        doc_tmp.OptionReadEncoding = true;
        doc_tmp.OptionFixNestedTags = true;
        doc_tmp.OptionDefaultStreamEncoding = Encoding.UTF8;

                doc_tmp.LoadHtml(tmp.InnerHtml);
                doc_tmp.Save(Console.Out);


Related

许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow