如何获取UTF-8格式的网站标题?
How to get title of a website in UTF-8 format?
我想获取网站的标题。我正在使用client.Encoding,几乎完美,但有一点不对。
它 returns 我 "Budapeşte'de gezilecek yerler | Skyscanner Haberler" 但标题有撇号而不是 unicode。
土耳其语字符“ş”可以。
string baslikCek()
{
Uri url = new Uri("https://www.skyscanner.com.tr/haberler/budapestede-gezilecek-yerler");
WebClient client = new WebClient();
client.Encoding = Encoding.UTF8;
string html = client.DownloadString(url);
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(html);
String title = (from x in doc.DocumentNode.Descendants()
where x.Name.ToLower() == "title"
select x.InnerText).FirstOrDefault().ToString();
return title;
}
此处显示的示例不正确,'
缺少结尾的 ;
。
但是从服务器上看是正确的,所以你可以这样做:
return System.Net.WebUtility.HtmlDecode(title);
这和Encoding.UTF8
不一样,是字符串数据的二进制编码
我想获取网站的标题。我正在使用client.Encoding,几乎完美,但有一点不对。
它 returns 我 "Budapeşte'de gezilecek yerler | Skyscanner Haberler" 但标题有撇号而不是 unicode。
土耳其语字符“ş”可以。
string baslikCek()
{
Uri url = new Uri("https://www.skyscanner.com.tr/haberler/budapestede-gezilecek-yerler");
WebClient client = new WebClient();
client.Encoding = Encoding.UTF8;
string html = client.DownloadString(url);
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(html);
String title = (from x in doc.DocumentNode.Descendants()
where x.Name.ToLower() == "title"
select x.InnerText).FirstOrDefault().ToString();
return title;
}
此处显示的示例不正确,'
缺少结尾的 ;
。
但是从服务器上看是正确的,所以你可以这样做:
return System.Net.WebUtility.HtmlDecode(title);
这和Encoding.UTF8
不一样,是字符串数据的二进制编码